博客
关于我
L83. 删除排序链表中的重复元素
阅读量:226 次
发布时间:2019-02-28

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

在一个已排序的链表中删除重复元素,可以通过以下步骤实现:

  • 初始化指针:创建一个当前指针current指向链表的头节点,创建一个前指针prev指向一个伪头节点,用于记录前一个处理过的节点。

  • 遍历链表:使用一个循环遍历链表,直到currentcurrent.next为空。

  • 检查重复元素:在每次循环中,检查current节点的值是否与current.next节点的值相同。如果相同,跳过current.next节点,并将current指向current.next.next,这样可以跳过重复的元素。

  • 更新指针:如果没有重复元素,更新prev指针指向current,然后将current指向current.next,继续遍历下一个节点。

  • 返回结果:当遍历结束后,返回链表的头节点,因为即使头节点有重复,伪头节点的next指向正确的新链表头部。

  • 以下是实现代码:

    class Solution {    public ListNode deleteDuplicates(ListNode head) {        if (head == null) return null;        ListNode prev = new ListNode(0);        prev.next = head;        ListNode current = head;        while (current != null && current.next != null) {            if (current.val == current.next.val) {                current = current.next.next;            } else {                prev.next = current;                prev = current;                current = current.next;            }        }        return prev.next;    }}

    示例1:输入:1 -> 1 -> 2输出:1 -> 2

    示例2:输入:1 -> 1 -> 2 -> 3 -> 3输出:1 -> 2 -> 3

    这种方法使用两个指针,时间复杂度为O(n),空间复杂度为O(1),高效且节省空间。

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

    你可能感兴趣的文章
    Network Sniffer and Connection Analyzer
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx 反向代理解决跨域问题
    查看>>
    nginx 后端获取真实ip
    查看>>
    Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    Objective-C实现A-Star算法(附完整源码)
    查看>>
    Objective-C实现atoi函数功能(附完整源码)
    查看>>
    Objective-C实现base64加密和base64解密算法(附完整源码)
    查看>>
    Objective-C实现base85 编码算法(附完整源码)
    查看>>
    Objective-C实现basic graphs基本图算法(附完整源码)
    查看>>
    Objective-C实现BCC校验计算(附完整源码)
    查看>>
    Objective-C实现bead sort珠排序算法(附完整源码)
    查看>>
    Objective-C实现BeadSort珠排序算法(附完整源码)
    查看>>
    Objective-C实现bellman ford贝尔曼福特算法(附完整源码)
    查看>>
    Objective-C实现bellman-ford贝尔曼-福特算法(附完整源码)
    查看>>
    Objective-C实现bellman-ford贝尔曼-福特算法(附完整源码)
    查看>>
    Objective-C实现BellmanFord贝尔曼-福特算法(附完整源码)
    查看>>