3
我做雙向鏈表類。問題與實現雙向鏈表
def remove(self, item):
current=self.__head
prev=None
found=False
if(self.__size>=1):
for i in range (0,self.__size):
if(current.getData()==item):
found=True
pos=i#save the position to pop
i=self.__size#leave the loop
else:
prev=current
current=current.getNext()
if(found==True):#excute only if the item is found
if(prev==None):#first item found
if(self.__size==1):
self.__head==None
self.__tail==None
current.setNext(None)
current.setPrevious(None)
else:#size bigger than 2
self.__head==current.getNext()
current.setNext(None)
else:
if(current.getNext()==None):#last item found
self.__tail==prev
current.setPrevious(None)
prev.setNext(None)
else:
Next=current.getNext()
current.setNext(None)
current.setPrevious(None)
Next.setPrevious(prev)
prev.setNext(Next)
self.pop(pos)
self.__size-=1
這就是我到目前爲止所做的。如果我運行下面
代碼這些是輸出,我得到
0
1
2
3
4 3
5 4 3
6 5 4 3
7 6 5 4 3
8 7 6 5 4 3
9 8 7 6 5 4
我期待第一4行(0〜3),以顯示任何和從第五個爲4,第6個爲5 4 ....等等。
最後我想9 8 7 6 5 4
如何修復代碼?問題的
謝謝soooooo多爲你help..I'll現在嘗試。 – 2013-03-07 04:32:44
,完美工作!再次,謝謝你 – 2013-03-07 04:42:05