LeetCode:26. 删除有序数组中的重复项

简介

题目链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/description/

解决方式:数组 + 双指针

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐查看Max大佬所作题解。

双指针

解题思路:双指针,一个指针 p 作为数组前面的唯一数字序列的最后一位,一个指针 q 迭代整个数组寻找与最后一位不同的数字,找到了就将其放在最后一位的下一位,然后 p、q 指针都下移,没找到则 q 指针下移继续寻找,直到迭代完整个数组。

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        // 边界处理
        if(nums.length == 0 || nums == null){
            return 0;
        }
        // 双指针
        // p相当于是目标唯一数字序列的最后一位,而q则用来迭代数组剩余元素
        int p = 0;
        int q = 1;
        while(q < nums.length){
            if(nums[p] != nums[q]){
                // 不相等,找到有序不严格递增数组的唯一元素,设置在唯一数字序列中
                nums[p + 1] = nums[q];
                // 唯一数字序列最后一位更迭
                p++; 
            }
            // 相等,q前进寻找不等元素
            q++;
        }
        // 返回结果
        return p + 1;
    }
}

双指针优化

初始数组可能每一个元素都唯一,所以可以避免自己覆盖自己。

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        // 边界处理
        if(nums.length == 0 || nums == null){
            return 0;
        }
        // 双指针
        // p相当于是目标唯一数字序列的最后一位,而q则用来迭代数组剩余元素
        int p = 0;
        int q = 1;
        while(q < nums.length){
            if(nums[p] != nums[q]){
                // 优化,防止数组中的所有元素本来就唯一
                if(q - p > 1){
                    // 不相等,找到有序不严格递增数组的唯一元素,设置在唯一数字序列中
                    nums[p + 1] = nums[q];
                }
                // 唯一数字序列最后一位更迭
                p++; 
            }
            // 相等,q前进寻找不等元素
            q++;
        }
        // 返回结果
        return p + 1;
    }
}
相关推荐
SilentSamsara5 分钟前
自定义上下文管理器实战:数据库连接池、文件锁与超时控制
开发语言·python·算法·青少年编程
清辞85312 分钟前
集合竞价选股程序开发学习
数据结构
吃着火锅x唱着歌13 分钟前
LeetCode 503.下一个更大元素II
算法·leetcode·职场和发展
_深海凉_16 分钟前
LeetCode热题100-将有序数组转换为二叉搜索树
数据结构·算法·leetcode
KaMeidebaby25 分钟前
卡梅德生物技术快报|单克隆抗体人源化 PEG 修饰质控方法体系构建与验证
服务器·前端·数据库·人工智能·算法·百度·新浪微博
不知名的老吴41 分钟前
二叉树的遍历算法之先序遍历
算法
liu****42 分钟前
第16届国赛蓝桥杯大赛C/C++大学B组
c语言·数据结构·c++·算法·蓝桥杯
SimpleLearingAI1 小时前
大模型推理框架总结解析
算法
ChoSeitaku1 小时前
04.数组
java·开发语言·数据结构
Σίσυφος19001 小时前
正则化数据并校准数据
人工智能·算法·机器学习