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

    你可能感兴趣的文章
    NOIP模拟测试19
    查看>>
    NOIp模拟赛二十九
    查看>>
    Vue3+element plus+sortablejs实现table列表拖拽
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    non linear processor
    查看>>
    Non-final field ‘code‘ in enum StateEnum‘
    查看>>
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NoNodeAvailableException None of the configured nodes are available异常
    查看>>
    Vue.js 学习总结(16)—— 为什么 :deep、/deep/、>>> 样式能穿透到子组件
    查看>>
    nopcommerce商城系统--文档整理
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    NoSQL数据库概述
    查看>>
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>
    NOTE:rfc5766-turn-server
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>