博客
关于我
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-mime类型
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    Node入门之创建第一个HelloNode
    查看>>
    NOIp2005 过河
    查看>>
    NOPI读取Excel
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm切换到淘宝源
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>
    NPOI之Excel——合并单元格、设置样式、输入公式
    查看>>
    NPOI利用多任务模式分批写入多个Excel
    查看>>
    NR,NF,FNR
    查看>>
    nrf开发笔记一开发软件
    查看>>
    NSDateFormatter的替代方法
    查看>>