问题:https://practice.geeksforgeeks.org/problems/array-of-alternate-ve-and-ve-nos1401/1#
我的代码如下所示。在我的电脑上以及在我在GFG上编译和运行时都能完美运行。但是当我提交代码时,它会在与
我已经添加了
注意:我不想要替代方案。我想知道为什么存在这个问题以及如何在将来防止它发生。
compile & run
中清除的相同输入上给我错误。我已经添加了
compile & run
和submit
的输出。
为什么打印出的数组大小超过了它的实际大小?#User function Template for python3
def updatePosIndex(array, pos_index,n,k):
for index in range(pos_index+k,n):
if array[index] >= 0:
pos_index = index
break
return pos_index
def updateNegIndex(array, neg_index,n, k):
for index in range(neg_index+k,n):
if array[index] < 0:
neg_index = index
break
return neg_index
def twoPointer(array,n):
pos_index = updatePosIndex(array, 0, n, 0)
neg_index = updateNegIndex(array, 0, n, 0)
flag = 1
for i in range(n):
if flag == 1:
if array[i] < 0:
array[i], array[pos_index] = array[pos_index], array[i]
neg_index = updateNegIndex(array, neg_index,n, 1)
pos_index = updatePosIndex(array, pos_index,n, 1)
elif flag == -1:
if array[i] >= 0:
array[i], array[neg_index] = array[neg_index], array[i]
pos_index = updatePosIndex(array, pos_index,n, 1)
neg_index = updateNegIndex(array, neg_index,n, 1)
flag = flag*-1
return array
class Solution:
def rearrange(self,arr, n):
arr = twoPointer(arr,n)
arr = arr[:n]
return arr
#{
# Driver Code Starts
#Initial Template for Python 3
if __name__ == '__main__':
tc = int(input())
while tc > 0:
n = int(input())
arr = list(map(int, input().strip().split()))
ob = Solution()
ob.rearrange(arr, n)
for x in arr:
print(x, end=" ")
tc -= 1
# } Driver Code Ends
注意:我不想要替代方案。我想知道为什么存在这个问题以及如何在将来防止它发生。
tc
是什么? - user202729