(LeetCode 面试经典 150 题) 82. 删除排序链表中的重复元素 II (链表)

题目:82. 删除排序链表中的重复元素 II


思路:链表,时间复杂度0(n)。

C++版本:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
    	//避免处理完后为空的情况
        ListNode new_head(0,head);
        ListNode *cur=&new_head;
        // 每次判断都判断两个连续相邻节点
        while(cur->next && cur->next->next){
            int val=cur->next->val;
            // 相等的话,说明这些相等的都不要
            if(cur->next->next->val==val){
            	// 进入循环,直到下一个节点不和val相等为止
                while(cur->next && cur->next->val==val){
                    cur->next=cur->next->next;
                }
            }else{
                cur=cur->next;
            }
        }
        return new_head.next;
    }
};

JAVA版本:

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        ListNode new_head=new ListNode(0,head);
        ListNode cur=new_head;
        while(cur.next!=null && cur.next.next!=null){
            int val=cur.next.val;
            if(cur.next.next.val==val){
                while(cur.next!=null && cur.next.val==val){
                    cur.next=cur.next.next;
                }
            }else{
                cur=cur.next;
            }
        }
        return new_head.next;
    }
}

GO版本:

go 复制代码
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func deleteDuplicates(head *ListNode) *ListNode {
    new_head:=&ListNode{Val:0,Next:head}
    cur:=new_head
    for cur.Next!=nil && cur.Next.Next!=nil {
        val:=cur.Next.Val
        if cur.Next.Next.Val==val {
            for cur.Next!=nil && cur.Next.Val==val {
                cur.Next=cur.Next.Next
            }
        }else{
            cur=cur.Next
        }
    }
    return new_head.Next
}
相关推荐
武子康37 分钟前
Java-136 深入浅出 MySQL Spring Boot @Transactional 使用指南:事务传播、隔离级别与异常回滚策略
java·数据库·spring boot·mysql·性能优化·系统架构·事务
saber_andlibert41 分钟前
【Linux】深入理解Linux的进程(一)
linux·运维·服务器·开发语言·c++
YXXY3133 小时前
算法练习(C++)---双指针
c++
玖笙&5 小时前
✨WPF编程基础【1.3】:XAML 名称空间
c++·wpf·visual studio
玖笙&5 小时前
✨WPF编程基础【1.4】:类型转换器(含示例及源码)
c++·wpf·visual studio
微笑尅乐7 小时前
力扣350.两个数组的交集II
java·算法·leetcode·动态规划
lypzcgf7 小时前
Coze源码分析-资源库-删除数据库-后端源码-流程/核心技术/总结
数据库·go·coze·coze源码分析·智能体平台·ai应用平台·agent平台
rzjslSe7 小时前
【JavaGuide学习笔记】理解并发(Concurrency)与并行(Parallelism)的区别
java·笔记·学习
青柠编程8 小时前
基于Spring Boot的竞赛管理系统架构设计
java·spring boot·后端
꒰ঌ 安卓开发໒꒱8 小时前
Java面试-并发面试(二)
java·开发语言·面试