力扣每日一题83:删除排序数组中的重复元素

题目描述:

给定一个已排序的链表的头 head删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表

示例 1:

复制代码
输入:head = [1,1,2]
输出:[1,2]

示例 2:

复制代码
输入:head = [1,1,2,3,3]
输出:[1,2,3]

提示:

  • 链表中节点数目在范围 [0, 300]
  • -100 <= Node.val <= 100
  • 题目数据保证链表已经按升序 排列

通过次数

623K

提交次数

1.2M

通过率

53.2%

思路和题解:

一个指针cur指向前一节点,一个指针p指向当前节点,如果p->next->val==p->val==x,p就后移,移到p->val!=x时,cur->next->next=p;直到遍历完整个链表。

代码:

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) {
        if(head==NULL) return head;
        ListNode *p=head,Head,*cur;
        Head.next=head;
        cur=&Head;
        while(p)
        {
            if(p->next==NULL) break;
            if(p->val!=p->next->val)
            {
                cur=p;
                p=p->next;
            }
            else
            {
                p=p->next;
                while(p&&p->val==cur->next->val)
                {
                    p=p->next;
                }
                cur->next->next=p;
            }
        }
        return Head.next;
    }
};
相关推荐
Robot_Nav17 分钟前
TD3 —— 双延迟深度确定性策略梯度算法文献解读
算法·td3·drl
斯维赤19 分钟前
每天学习一个小算法:归并排序
学习·算法·排序算法
王老师青少年编程24 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:区间覆盖(加强版)
c++·算法·贪心·csp·信奥赛·区间贪心·区间覆盖(加强版)
碧海银沙音频科技研究院30 分钟前
杰理项目开发大全课程
人工智能·深度学习·算法
风一样的航哥1 小时前
LeetCode 2615 等值距离和:前缀和优化O(n)解法深度解析
数据结构·算法·leetcode
生成论实验室1 小时前
生成态势猜想:一种统一的宇宙动力学语法
人工智能·科技·神经网络·算法·信息与通信
旖-旎2 小时前
深搜(二叉树的所有路径)(6)
c++·算法·leetcode·深度优先·递归
啦啦啦_99992 小时前
3. KNN算法之 常用的距离度量方式(欧式&曼哈顿&切比雪夫&闵式距离)
算法
朝风工作室2 小时前
实时全景拼接|支持任意路数输入,8*8K RTX3050 实测 10ms 内
图像处理·算法·计算机视觉
nianniannnn3 小时前
HNU计算机系统期中题库详解(五)位运算与逻辑运算
算法·位运算·计算机系统