题解 | #删除有序链表中重复的元素-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,但实际上并没有真正删除掉重复的元素,只是断开了重复元素在原有链表中的连接,重复元素成为了一个孤孤单单的指针,没有被回收到它该去的地方。

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

全部评论

相关推荐

双飞二本嵌入式求拷打我是在 BOSS 上投递的简历,好多都没人回复,这是开场白和简历求大神帮忙看看。您好!我是2025届应届生,最快可在一周内上岗,能够实习六个月以上,并接受加班。以下是我的核心优势和相关经验:1. 嵌入式开发能力:   熟练掌握STM32系列单片机及其外设(如GPIO、定时器、ADC、DAC、I2C、SPI、UART等),能够独立完成硬件驱动开发和调试。  熟悉FreeRTOS实时操作系统,具备多任务调度和资源管理经验。  熟悉LVGL图形库开发,能够实现嵌入式设备的图形界面设计。2. 硬件设计能力:   具备PCB设计经验,曾为2023年工创赛物流搬运赛道设计小车主板,带领团队获得国家级银奖。   熟悉硬件原理图分析,能够快速理解并调试硬件电路。3. 机器人开发与竞赛经验:   在全国大学生智能车竞赛、ROS机器人竞赛中多次获得国家级奖项,具备丰富的机器人开发经验。   熟悉Linux环境,对ROS和ROS 2有一定了解,能够进行机器人系统的开发与调试。4. 编程能力:   熟悉C/C++,熟悉Python,能够高效完成嵌入式开发和算法实现。   具备良好的代码规范和文档编写能力。5. 团队协作与领导能力:   在多个项目中担任核心开发或团队负责人,具备良好的沟通能力和团队协作精神。   在工创赛中带领团队完成项目规划、任务分配和技术攻关,展现了较强的领导力。我对嵌入式开发、机器人技术和智能硬件充满热情,期待加入贵公司,与团队共同成长,为公司创造价值!如果有合适的岗位,欢迎随时联系我,期待进一步沟通!
沉淀一会:嵌入式就是狗屎
点赞 评论 收藏
分享
1个小白:可以考虑投一下字节
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

更多
牛客网
牛客企业服务