21.leetcode 备【蓝桥杯】 删除排序链表中的重复元素

一、题目

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

示例 1:

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

示例 2:

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

提示:

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

二、代码


/**
 * 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) {
        //deleteDuplicates传入的是一个链表,返回一个链表
        
        //当 当前节点与下一个结点都不为空的时候,我们进行不断地比较
        //定义一个指针first指向第一个节点,若相邻结点相等的话,则将将头节点的下一个的下一个节点链在头节点的后面
        //若相邻结点不相等,则将first指针向后移动,
        
        
        ListNode first = head;
        while(first != null && first.next != null) {
            if(first.val == first.next.val){
                first.next = first.next.next;
            }else{
                first = first.next; 
            }
        }
        return head;
    }
}

三、反思

1.解题思路:

可大致上说是用了两个指针,定义一个新的指针first也指向头节点,这个是不断地向后遍历的,

当前的指针所指的结点值和当前指针的下一个节点的值,如果相等的话,则将跳过当前的指针(即当前节点的下一个节点的下一个节点 链在当前节点的后面),如果不相等,则将指向当前节点的指针向后移动(first= first.next),

不断向后遍历的终止条件是:当前节点为空且当前节点的下一个节点也为空,循环结束时返回的是头节点(代表这整个链表)

相关推荐
火星机器人life2 小时前
基于ceres优化的3d激光雷达开源算法
算法·3d
虽千万人 吾往矣2 小时前
golang LeetCode 热题 100(动态规划)-更新中
算法·leetcode·动态规划
arnold662 小时前
华为OD E卷(100分)34-转盘寿司
算法·华为od
ZZTC3 小时前
Floyd算法及其扩展应用
算法
测试19983 小时前
外包干了2年,技术退步明显....
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
lshzdq3 小时前
【机器人】机械臂轨迹和转矩控制对比
人工智能·算法·机器人
2401_858286114 小时前
115.【C语言】数据结构之排序(希尔排序)
c语言·开发语言·数据结构·算法·排序算法
猫猫的小茶馆4 小时前
【数据结构】数据结构整体大纲
linux·数据结构·算法·ubuntu·嵌入式软件
u0107735144 小时前
【字符串】-Lc5-最长回文子串(中心扩展法)
java·算法
帅逼码农4 小时前
K-均值聚类算法
算法·均值算法·聚类