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;
    }
}
相关推荐
WitsMakeMen2 小时前
RoPE 算法原理?算法为什么只和相对位置有关
人工智能·算法·llm
WolfGang0073212 小时前
代码随想录算法训练营 Day09 | 栈与队列 part01
数据结构
0 0 02 小时前
CCF-CSP 38-4 月票发行【C++】考点:动态规划DP+矩阵快速幂
c++·算法·动态规划·矩阵快速幂
北漂Zachary2 小时前
Mysql中使用sql语句生成雪花算法Id
sql·mysql·算法
aini_lovee2 小时前
MATLAB圆锥滚子轴承滚子参数分析程序
人工智能·算法·matlab
_olone2 小时前
牛客每日一题:显生之宙(Java)
java·开发语言·算法·牛客
嫂子开门我是_我哥3 小时前
心电域泛化研究从0入门系列 | 第二篇:心电信号预处理全攻略——扫清域泛化建模的第一道障碍
人工智能·算法·ecg
wefg13 小时前
【算法】算数基本定理、分解质因数
算法
j_xxx404_3 小时前
力扣困难算法精解:串联所有单词的子串与最小覆盖子串
java·开发语言·c++·算法·leetcode·哈希算法