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

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

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

OJ链接

  • 这里的非递增是什么意思?
  • 就是反过来的,递减,不能说是乱序~~
  • 也就是后一个比前一个小
  • 也就是和非递减等价,后一个比前一个大~~

  • 所以非递增和非严格递增是不一样的~~

  • 这里本质上的一个算法是去重算法,就是要把重复的去掉,只留下一个~~

思路:

  • 本质是dst在后面依次找 跟src位置不相等,依次从前往后覆盖~~

代码如下:

int removeDuplicates(int* nums, int numsSize){
    int src = 0;
    int dst = 1;
    while(dst < numsSize)
    {
        if(nums[src]!=nums[dst])
        {
            nums[++src] = nums[dst++];
        }
        else
        {
            ++dst;
        }
    }
    return src + 1;
}
目录
打赏
0
0
1
0
7
分享
相关文章
|
3月前
leetCode(删除有序数组中的重复项)
如何在不使用额外空间的情况下,通过双指针法原地删除有序数组中的重复项。
39 2
LeetCode------合并两个有序数组(4)【数组】
这篇文章介绍了LeetCode上的"合并两个有序数组"问题,并提供了三种解法:第一种是使用Java的Arrays.sort()方法直接对合并后的数组进行排序;第二种是使用辅助数组和双指针技术进行合并;第三种则是从后向前的双指针方法,避免了使用额外的辅助数组。
LeetCode------合并两个有序数组(4)【数组】
|
3月前
【LeetCode-每日一题】 删除排序数组中的重复项
【LeetCode-每日一题】 删除排序数组中的重复项
28 4
|
3月前
【LeetCode 48】108.将有序数组转换为二叉搜索树
【LeetCode 48】108.将有序数组转换为二叉搜索树
46 0
LeetCode第26题删除有序数组中的重复项
这篇文章介绍了LeetCode第26题"删除有序数组中的重复项"的解题方法,通过使用双指针技巧,高效地去除数组中的相邻重复元素。
LeetCode第26题删除有序数组中的重复项
LeetCode第80题删除有序数组中的重复项 II
文章介绍了LeetCode第80题"删除有序数组中的重复项 II"的解法,利用双指针技术在O(1)空间复杂度内原地删除重复元素,并总结了双指针技术在处理有序数组问题中的应用。
LeetCode第80题删除有序数组中的重复项 II
LeetCode第88题合并两个有序数组
文章分享了LeetCode第88题"合并两个有序数组"的解法,通过从后向前的合并策略避免了数组元素的前移,使用三个指针高效地完成了合并过程。
|
5月前
|
【Leetcode刷题Python】108. 将有序数组转换为二叉搜索树
LeetCode上108号问题"将有序数组转换为二叉搜索树"的Python实现,通过递归选取数组中间值作为根节点,构建高度平衡的二叉搜索树。
33 2
|
5月前
|
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
61 0
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
50 0