(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
}
相关推荐
YC运维3 分钟前
Ansible题目全解析与答案
java·算法·ansible
CYRUS_STUDIO3 分钟前
LLVM 不止能编译!自定义 Pass + 定制 clang 实现函数名加密
c语言·c++·llvm
程序员清风12 分钟前
贝壳一面:年轻代回收频率太高,如何定位?
java·后端·面试
CYRUS_STUDIO17 分钟前
OLLVM 移植 LLVM 18 实战,轻松实现 C&C++ 代码混淆
c语言·c++·llvm
落羽的落羽19 分钟前
【C++】简单介绍lambda表达式
c++·学习
考虑考虑24 分钟前
Java实现字节转bcd编码
java·后端·java ee
Dovis(誓平步青云)25 分钟前
《探索C++11:现代语法的内存管理优化“性能指针”(下篇)》
开发语言·jvm·c++
软件开发-NETKF88881 小时前
JSP到Tomcat特详细教程
java·开发语言·tomcat·jsp·项目运行
渣哥1 小时前
为什么 JDK 1.8 要给 HashMap 加红黑树?
java
我登哥MVP1 小时前
Java 网络编程学习笔记
java·网络·学习