• 注意链表的尾部


    今天做了Leetcode上面一道题Remove Duplicates from Sorted List II,要去去除链表中重复的节点,代码如下

     1 /**
     2  * Definition for singly-linked list.
     3  * struct ListNode {
     4  *     int val;
     5  *     ListNode *next;
     6  *     ListNode(int x) : val(x), next(NULL) {}
     7  * };
     8  */
     9 class Solution {
    10 public:
    11     ListNode *deleteDuplicates(ListNode *head) {
    12         if(head==NULL||head->next==NULL)
    13         {
    14             return head;
    15         }
    16         ListNode *p=head,*prev=new ListNode(0),*head2=prev;
    17         int count=0;
    18         while(p->next!=NULL)
    19         {
    20             if(count==0&&p->val!=p->next->val)
    21             {
    22                 prev->next=p;
    23                 prev=p;
    24             }
    25             else if(p->val==p->next->val)
    26             {
    27                 count++;
    28             }
    29             else if(count>0)
    30             {
    31                 count=0; 
    32             }
    33             p=p->next;
    34         }
    35         if(count==0)
    36         {
    37             prev->next=p;
    38         }
    39        // else
    40        //{
    41        //     prev->next=NULL;
    42        //}
    43         head=head2->next;
    44         delete head2;
    45         return head;
    46     }
    47 };

    注意到39-42行被注释掉的代码,注释掉,会怎么样?

    分析一下算法,count表示前面与当前指针val相等的节点个数,对于末尾指针,前面如果没有与其数值相等,则加入链表,否则,则不加入链表,但是,如果末尾指针前面存在与其相等的数,是不是可以不用管它?不是的,因为是原地对链表操作,所以如果不处理的画,那么最后prev的next还是会指向另一个节点,而这个节点并不是我们想要的,所以39-42行必须将prev的next指向空指针。当然对于存在重复的节点,可以直接delete之,如果该节点是分配到堆上的话。

  • 相关阅读:
    Linux目录
    find命令
    107. Binary Tree Level Order Traversal II
    grep命令
    110. Balanced Binary Tree
    111. Minimum Depth of Binary Tree
    什么是泛型
    自动装箱与拆箱
    HDU 3001 Travelling (状压DP + BFS)
    POJ 3411 Paid Roads (状态压缩+BFS)
  • 原文地址:https://www.cnblogs.com/clark-lee/p/3840857.html
Copyright © 2020-2023  润新知