删除排序链表(或数组)中的重复元素

这篇博客介绍了如何删除排序链表和数组中的重复元素,主要利用双指针策略来优化时间复杂度,避免暴力求解。文章通过示例和代码解释了双指针方法的工作原理,并探讨了将这种方法应用于数组的情况。
摘要由CSDN通过智能技术生成

删除排序链表(或数组)中的重复元素

题目描述

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

示例

输入: 1->1->2
输出: 1->2
示例 2:

输入: 1->1->2->3->3
输出: 1->2

分析

  • 第一种方法:暴力法解决,依次从链表中取元素,再拿该元素对链表顺序匹配,时间复杂度为O(n^2),但凡有点算法基础,都不会采用这种策略,因为太der了…
  • 像这种线性结构的算法题,如数组、链表等,我们有更强大的策略去解决这种问题 - 双指针

直接看代码

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
   
    public ListNode deleteDuplicates(ListNode head) {
   
        if (head==null) return  head ; //判空

        ListNode headCopy = head ;
    /*  *在Java中,操作链表,需要使用引用,以保持head的内部结构指向不被修改
        *引用(copy)直接修改的是head的内存,而返回的head始终保持指向第一个结点
        *C++则也是创建一个copy链表来操作,保持head的内部结构指向不被修改*/


        while (headCopy.next!=null){
   

            if (headCopy.val == headCopy.next.val){
   
                //立即删除head结点
                headCopy.val = headCopy.next.val ;
                headCopy.next =  headCopy.next.next  ;
                //保持快慢指针不动
            }else {
   
                headCopy = headCopy.next ;
            }

        }
        return  head ; //返回head而不是headcopy
    }
}

为了更加直观的体现我们的双指针,我把代码改成下面这种形式

/**
 * Definition for singly-linked list.
 * public class ListNode {
   
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
    val = x; }
 * }
 */
class Solution {
   
    public ListNode deleteDuplicates(ListNode head) {
   
        if (head==null) return  head ; //判空

        ListNode headCopy = head ;
    /*  *在Java中,操作链表,需要使用引用,以保持head的内部结构指向不被修改
        *引用(copy)直接修改的是head的内存,而返回的head始终保持指向第一个结点
        *C++则也是创建一个copy链表来操作,保持head的内部结构指向不被修改*/


        while (headCopy.next!=null){
   
            int pslow = headCopy.val ;
            int pfast = headCopy.next.val ; 
            if (pslow == pfast){
   
                //立即删除head结点
                headCopy.val = headCopy.next.val ;
                headCopy.next =  headCopy.next.next  ;

            }else {
   
                headCopy = headCopy.next ;
            }

        }
        return  head ; //返回head而不是headcopy
    }
}

分析

    • 1
      点赞
    • 2
      收藏
      觉得还不错? 一键收藏
    • 0
      评论

    “相关推荐”对你有帮助么?

    • 非常没帮助
    • 没帮助
    • 一般
    • 有帮助
    • 非常有帮助
    提交
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值