2014-03-07 165 views
0

我試圖刪除雙向鏈表中的一個節點,但這裏的問題是,當我有清單:7-6-5-4-3-2-1,並嘗試刪除3,我得到7-6-5-4-3,我無法弄清楚錯誤。請幫忙!雙鏈表:刪除節點

void RemoveItem(int itm) 
{   
    if (Head->item == itm) { 
     Head = Head -> Next;  
     cout<<"\nItem is at 1st node & removed\n";flag=1; 
    } 
    else if (Head->Next == NULL) {   
     cout<<" \n This is 1-node list & item not in it\n"; 
    } 
    else {     
     node *current, *del = Head; 
     while(del->Next != NULL && del->item != itm) { 
      del = del->Next; 
     } 
     current = del; 
     current->Next = del->Next; 
     del->Next->previous = current; 
     delete(del); 
     del->Next = NULL; 
     flag = 1; 
    } 
} 

回答

0

要刪除重複的節點,直到到達刪除的節點德爾然後設置: 僞代碼:

del.prev.next = del.next 

del.next.prev = del.prev 
+0

它沒有這樣工作,與以前相同的輸出。 :/ –

+0

@AliZahr擺脫其他一切包括設置當前刪除和只是使用這個邏輯 –

+0

我做了,但現在我進入無限循環:/ 這裏的代碼:while(del-> Next!= NULL && del-> item!= itm){del | del-> Next; } del-> Next-> previous = del-> previous; del-> previous-> Next = del-> Next; 刪除(del); –

0

這是沒有意義的:

current = del; 
current->Next = del->Next; 

,因爲它是一樣的

del->Next = del->Next; 

嘗試是這樣的

// some global int flag = 0 
// some global node* Head pointing to head of list 

void RemoveItem(int itm) {   
    if (Head->item == itm) { 
    node* del = Head; 
    Head = Head -> Next; 
    delete(del);  
    cout<<"\nItem is at 1st node & removed\n"; 
    flag=1; 
    return; 
    } 
    if (Head->Next == NULL) {    
    cout<<" \n This is 1-node list & item not in it\n"; 
    return; 
    }     
    node* current = Head; 
    node* del = Head; 

    while(del->Next != NULL && del->item != itm) { 
    del = del->Next; 
    } 

    // reached with del->Next == NULL || del->item == itm 
    current = del->previous; 
    if (del->Next == NULL) { 
    // at end of list 
    if (del->item != item) { 
     // item not found 
     // todo: signal error 
     return; 
    } 
    current->Next = NULL; 
    } else { 
    del->Next->previous = current; 
    current->Next = del->Next; 
    } 
    delete(del); 
    flag = 1; 
} 

注:我定了許多錯誤,並試圖保持它的邏輯中。我會寫它與衆不同。