博客
关于我
deleteDuplicates-删除排序链表中的重复元素
阅读量:652 次
发布时间:2019-03-15

本文共 1167 字,大约阅读时间需要 3 分钟。

给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。

步骤详解

要在排序链表中删除所有重复的元素,可以使用两个指针的方法,具体步骤如下:

  • 初始化指针:将两个指针l和r分别指向链表的首节点和次节点。
  • 遍历链表:从链表的第二个节点开始,用指针r遍历整个链表。
  • 比较节点值:如果r节点的值大于l节点的值,则将l指针跳转到r节点位置,并将r指针继续移动到下一个节点。
  • 处理重复节点:当r遍历完所有节点后,检查l节点后面的节点。如果有并且相等,则将l节点后面节点设置为null,确保最后一个节点不与前面重复。
  • 返回结果:返回处理后的链表。
  • 代码实现

    class Solution {    public ListNode deleteDuplicates(ListNode head) {        if (head == null) {            return head;        }        ListNode l = head;        ListNode r = head.next;        while (r != null) {            if (r.val > l.val) {                l.next = r;                l = r;            }            r = r.next;        }        if (l.next != null && l.val == l.next.val) {            l.next = null;        }        return head;    }}

    功能测试

    测试一下该算法是否正常工作。

    测试用例1

    • 输入:1 -> 1 -> 2
    • 预期输出:1 -> 2

    代码运行过程:

    • l = 第一个1,r移动到第二个1(val=1)。由于r.val <= l.val,r移动到2(val=2)。
    • 2 > 1,l.next = 2,l移动到2。r移动到null。
    • 循环结束后,检查l.next为null,因此结果正确。

    测试用例2

    • 输入:1 -> 1 -> 2 -> 3 -> 3
    • 预期输出:1 -> 2 -> 3

    代码运行过程:

    • l = 1,r = 1(val=1)。r.val <= l.val,r移动到2。
    • 2 > 1,l.next = 2,l移动到2。r移动到3。
    • 3 > 2,l.next = 3,l移动到3。r移动到3。
    • 3 <= 3,无法进入if语句,r移动到null。
    • 循环结束后,检查l.next为3,可能等于l的值(3 == 3),因此将其设为null,得到1 -> 2 -> 3。

    通过这些测试,算法正确处理了所有情况。

    转载地址:http://pejmz.baihongyu.com/

    你可能感兴趣的文章
    nodejs图片转换字节保存
    查看>>
    nodejs在Liunx上的部署生产方式-PM2
    查看>>
    nodejs基于art-template模板引擎生成
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs学习笔记一——nodejs安装
    查看>>
    vue3+Element-plus icon图标无法显示的问题(已解决)
    查看>>
    NodeJS实现跨域的方法( 4种 )
    查看>>
    nodejs封装http请求
    查看>>
    nodejs常用组件
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    nodejs支持ssi实现include shtml页面
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs概览: 思维导图、核心技术、应用场景
    查看>>
    nodejs模块——fs模块
    查看>>