题解 | #删除有序链表中重复的元素-I#

删除有序链表中重复的元素-I

http://www.nowcoder.com/practice/c087914fae584da886a0091e877f2c79

NC25 删除有序链表中重复的元素-I

题意分析:

给一个有序的链表,删除其中的重复的元素。

题解一(遍历):

图片说明

我们初始化两个指针,指针flag指向当前编制元素,代表有其他指针的值与其相同的标志点。设置指针p,用于遍历链表。

当flag==p时候,p指向其下一个元素

当flag!=p时候,我们需要检查指针flag和指针p指向的值是否相同。如上图中间一部分,指针p和指针flag虽然指向不同的位置,但是其值相等,这是我们需要删除指针p指向的元素,我们的删除步骤如下:

  1. 首先flag指针的指向的下一个元素指向p的下一个元素。
  2. 删除指针p指向的元素
  3. 将指针p指向flag指向的下一个元素

通过上面散步,我们删除了重复的元素

当flag!=p时候,并且他们的值不相等,我们将指针flag指向p指向的元素,之后重复上面的步骤。

当p为空的时候,说明我们已经把重复元素删除完毕,返回链表的头指针即可。

将上面步骤书写成代码:

ListNode* deleteDuplicates(ListNode* head) {
        ListNode *flag = head;
        ListNode *p = head;
        while(p){
            if(flag==p){
                 //当flag指针与遍历所用指针p重合,p移动到下一个位置,不用做删除
                p = p->next;
            }
            else if(flag!=p&&flag->val!=p->val){
                //当flag与p没有重合,且他们值不等,更新flag到p
                flag = p;
            }
            else if(flag!=p&&flag->val==p->val){
                //当flag与p没有重合,但他们的值相等,开始删除p
                flag->next = p->next;
                free(p);
                p = flag->next;
            }
        }
        return head;
    }

值得注意的是,上面删除元素的步骤也有一个错误的写法:

  1. 将指针p指向p的下一个元素。
  2. 将指针flag的下一个指向改为指向指针p。

这里我们并没有free 重复的元素,而是忽略了它。代码如下

 ListNode* deleteDuplicates(ListNode* head) {
        ListNode *flag = head;
        ListNode *p = head;
        while(p){
            if(flag==p){
                p = p->next;
            }
            else if(flag!=p&&flag->val!=p->val){
                flag = p;
            }
            else if(flag!=p&&flag->val==p->val){
            //与上面不同的地方
                p = p->next;
                flag->next= p;
            }
        }
        return head;
    }

这种写法虽然能够ac,但实际上并没有真正删除掉重复的元素,只是断开了重复元素在原有链表中的连接,重复元素成为了一个孤孤单单的指针,没有被回收到它该去的地方。

时间复杂度:,将链表遍历了一遍。
空间复杂度:,用到了常数个指针。

全部评论

相关推荐

关于我大学本科四年,想了很多,但还是不知道该怎么动笔 “大学四年,是我从懵懂少年走向职场青年的转折期。这一路跌跌撞撞,有迷茫,有遗憾,也有成长和决心。” 大一刚进来时仍然有高中那股学习劲,经常一个人去图书馆学高等数学,但后面劲头一过便开始在宿舍开启躺平生活(现在想想那段时间真的很爽,无忧无虑)。由于大一担任班干部,所以经常要跟其他班的班干部交流,在此期间认识了隔壁班的一位女生,短发而很可爱,因为很多团建还有比赛都是我们两班一起参加的,而且我和她都是负责人,所以交集很多,后面慢慢地彼此对产生了好感,所以在大一刚开学的2个月后,我们在一起了,彼此之前都是初恋。但当时我真的是太太太直男了,对感情的想...
真烦好烦真烦:骗哥们可以,别把你自己也骗到了就行。哥们被你骗了真无所谓的,打个哈哈就过了。但希望你打完这段话后擦一下眼角,别让眼泪掉在手机屏幕上了就行。你说的这些话,哥们信一下也是没什么的。还能让你有个心里安慰,但这种话说出来骗骗兄弟就差不多得了,哥们信你一下也不会少块肉,但是你别搞得自己也当真了就行。哥们被你骗一下是真无所谓的,兄弟笑笑也就过去了。真不是哥们想要破你防,你擦擦眼泪好好想想,除了兄弟谁还会信你这些话?
点赞 评论 收藏
分享
评论
1
3
分享

创作者周榜

更多
牛客网
牛客企业服务