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

本文共 1047 字,大约阅读时间需要 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/

    你可能感兴趣的文章
    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模块
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>