博客
关于我
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/

    你可能感兴趣的文章
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    Mysql join原理
    查看>>
    mysql order by多个字段排序
    查看>>
    MySQL Order By实现原理分析和Filesort优化
    查看>>
    mysql problems
    查看>>
    mysql replace first,MySQL中处理各种重复的一些方法
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    Mysql Row_Format 参数讲解
    查看>>
    mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
    查看>>
    MySQL Server 5.5安装记录
    查看>>
    mysql slave 停了_slave 停止。求解决方法
    查看>>
    MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    mysql union orderby 无效
    查看>>
    mysql where中如何判断不为空
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>