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;
    }
}
相关推荐
写代码写到手抽筋1 天前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.1 天前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz111 天前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi81 天前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯1 天前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息1 天前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony111 天前
【JVM】根可达算法
jvm·算法
艾iYYY1 天前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion1 天前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode