【数据结构与算法 | 基础篇】[链表专题]力扣82

简介: 【数据结构与算法 | 基础篇】[链表专题]力扣82

1. 力扣82 : 删除排序链表中的重复元素

题 :

给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。
 
 
 
示例 1:
 
 
输入:head = [1,2,3,3,4,4,5]
输出:[1,2,5]
示例 2:
 
 
输入:head = [1,1,1,2,3]
输出:[2,3]
 
 
提示:
 
链表中节点数目在范围 [0, 300] 内
-100 <= Node.val <= 100
题目数据保证链表已经按升序 排列1. 给定一个已排

思路1 : 递归法


  • 标准开头,如果head为空链表或该链表只有一个节点,直接返回.
  • 如果head指向的节点的数据域与其下一个节点的数据域相等,则p记录head的下下一个节点.p节点仍然有可能与head节点的数据域相等.while循环.如果p的数据域与head的数据域相等,则将head后移一个节点.如果不相等,则跳出循环.因为p之前的节点按照规则都需要删除.所以需要返回p的节点的递归结果.
  • 如果head指向的节点的数据域与下一个节点的数据域不想等,则head连接head的下一个节点的递归结果.并返回head.

解1 :

class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        if (head.val == head.next.val) {
            ListNode p = head.next.next;
            while (p != null) {
                if (p.val == head.val) {
                    p = p.next;
                } else {
                    break;
                }
            }
            return deleteDuplicates(p);
        }
        head.next = deleteDuplicates(head.next);
        return head;
    }
}

思路2 : 一次遍历(官方题解)


  • 头节点有可能被删除,所以设置哨兵节点dummy.cur被初始化指向哨兵节点.问题变为判断cur.next与cur.next.next是否需要删除.第一次循环时,判断第一个节点的数据域是否与第二个节点相等,如果相等,p指向第二个节点的next节点.如果p为null,cur.next指向null.如果不相等,判断p节点的数据域是否与cur.next的数据域相等,如果相等,则指向的该节点也需要删除,即p=p.next.如果不想等,退出内层循环,cur.next指向p.(如出现1 2 2 2 3这种情况).
  • 当最后一次while循环时,此时cur指向链表的倒第三个节点.判断cur.next的数据域是否与cur.next.next的相等.如果相等,p为null.则cur.next=null.如果不想等,倒第一和二的节点无需删除.cur=cur.next.while条件不满足.退出循环.

解2 :

class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        ListNode dummy = new ListNode(10086, head);
        ListNode cur = dummy;
        while (cur.next != null && cur.next.next != null) {
            if (cur.next.val == cur.next.next.val) {
                ListNode p = cur.next.next.next;
                while (p != null) {
                    if (p.val == cur.next.val) {
                        p = p.next;
                    } else {
                        break;
                    }
                }
                cur.next = p;
            } else {
                cur = cur.next;
            }
        }
        return dummy.next;
    }
}
相关文章
|
9天前
|
Java
java数据结构,双向链表的实现
文章介绍了双向链表的实现,包括数据结构定义、插入和删除操作的代码实现,以及双向链表的其他操作方法,并提供了完整的Java代码实现。
java数据结构,双向链表的实现
|
1月前
|
存储 Java 索引
【数据结构】链表从实现到应用,保姆级攻略
本文详细介绍了链表这一重要数据结构。链表与数组不同,其元素在内存中非连续分布,通过指针连接。Java中链表常用于需动态添加或删除元素的场景。文章首先解释了单向链表的基本概念,包括节点定义及各种操作如插入、删除等的实现方法。随后介绍了双向链表,说明了其拥有前后两个指针的特点,并展示了相关操作的代码实现。最后,对比了ArrayList与LinkedList的不同之处,包括它们底层实现、时间复杂度以及适用场景等方面。
44 10
【数据结构】链表从实现到应用,保姆级攻略
|
2月前
|
存储 算法
【初阶数据结构篇】顺序表和链表算法题
此题可以先找到中间节点,然后把后半部分逆置,最近前后两部分一一比对,如果节点的值全部相同,则即为回文。
|
2月前
|
存储 测试技术
【初阶数据结构篇】双向链表的实现(赋源码)
因为头结点的存在,plist指针始终指向头结点,不会改变。
|
2月前
|
存储 测试技术
【初阶数据结构篇】单链表的实现(附源码)
在尾插/尾删中,都需要依据链表是否为空/链表是否多于一个节点来分情况讨论,目的是避免对空指针进行解引用造成的错误。
|
2月前
|
算法
【数据结构与算法】共享双向链表
【数据结构与算法】共享双向链表
14 0
|
2月前
|
算法
【数据结构与算法】双向链表
【数据结构与算法】双向链表
13 0
|
2月前
|
算法
【数据结构与算法】循环链表
【数据结构与算法】循环链表
15 0
|
3天前
|
传感器 算法 C语言
基于无线传感器网络的节点分簇算法matlab仿真
该程序对传感器网络进行分簇,考虑节点能量状态、拓扑位置及孤立节点等因素。相较于LEACH算法,本程序评估网络持续时间、节点死亡趋势及能量消耗。使用MATLAB 2022a版本运行,展示了节点能量管理优化及网络生命周期延长的效果。通过簇头管理和数据融合,实现了能量高效和网络可扩展性。
|
1月前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
下一篇
无影云桌面