面试经典 150 题 ---- 删除排序数组中的重复项

面试经典 150 题 ---- 删除排序数组中的重复项

删除排序数组中的重复项

方法一:双指针

有是一个原地修改的题目,大概率依旧是双指针。

定义 right 表示遍历数组到达的下标位置,left 指针表示下一个不同元素将要填入的下标位置,两个指针初始都指向 1。

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int len = nums.length;
        int left = 1, right = 1;
        while (right < len) {
            if (nums[right] != nums[right - 1]) {
                nums[left] = nums[right];
                left ++ ;
            }
            right ++ ;
        }
        return left;
    }
}
相关推荐
逆境清醒26 分钟前
软考高项常见英语词汇(2)
职场和发展·信息系统项目管理师·英语·计算机软考
常利兵1 小时前
吃透Java操作符高阶:位操作符+赋值操作符全解析(Java&C区别+实战技巧+面试考点)
java·c语言·面试
NEXT063 小时前
防抖(Debounce)与节流(Throttle)解析
前端·javascript·面试
兆子龙6 小时前
深入 ahooks 3.0 useRequest 源码:插件化架构的精妙设计
javascript·面试
maplewen.7 小时前
C++11 返回值优化
开发语言·c++·面试
苏荷水7 小时前
万字总结LeetCode100(持续更新...)
java·算法·leetcode·职场和发展
UrbanJazzerati7 小时前
从零到一:用Python Tkinter打造专业的文件行删除工具(一)
后端·面试
不想秃头的程序员9 小时前
Vue3 子传父全解析:从基础用法到实战避坑
前端·vue.js·面试
TracyCoder1239 小时前
LeetCode Hot100(50/100)——153. 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展