C语言 详解如何删除有序数组中的重复项
删除有序数组中的重复项Ⅰ
a.思路
⭐定义变量 int dest=0,cur=1,nums[cur]与nums[dest]逐一比较。
⭐nums[cur]!=nums[dest],将nums[cur]放入dest下一个位置,更新dest。
⭐nums[cur]!=nums[dest],cur移动。
⭐cur==numsSize,结束。返回dest+1。
b.图解
c.代码
int removeDuplicates(int* nums, int numsSize) { if(numsSize==0) { return 0; } int dest=0; int cur=1; nums[dest]=nums[0]; //从cur==1 cur<numsSize while(cur<numsSize) { if(nums[cur]!=nums[dest]) { nums[++dest]=nums[cur++]; } else { cur++; } } return dest+1; }
d.思考
⭐如果给你一个无序的数组,去除重复的元素,该如何设计程序?
删除有序数组中的重复项Ⅱ
a.思路
⭐定义变量 int dest=0,cur=1,flag=1(表示0到dest,nums[dest]只出现过一次)。
⭐比较nums[cur]与nums[dest]。
⭐nums[cur]!=nums[dest],将nums[cur]放入dest下一个位置,++dest,更新flag(flag=1)。
⭐nums[cur]==nums[dest],如果dest所对应的flag为1,可将nums[cur]放入dest下一个位置,++dest, ++flag。如果dest所对应的flag为2,只移动cur.。
b.图解
c.代码
int removeDuplicates(int* nums, int numsSize) { int dest=0; int cur=1; int flag=1; nums[dest]=nums[0]; //从cur==1到cur<numsSize while(cur<numsSize) { if(nums[cur]!=nums[dest]) { nums[++dest]=nums[cur++]; flag=1; } else { if(flag==1) { nums[++dest]=nums[cur++]; ++flag; } else { cur++; } } } return dest+1; }
d.思考
⭐如果给定一个有序数组,删除重复出现的元素,使每个元素最多出现k次 ,返回删除后数组的新长度,该如何设计程序?(k为常数)
今天的算法题就分享到这里了,博主也会在后期更新更加优质的博文,如果对你有帮助的话,可以给个关注,顺便给个赞。
到此这篇关于C语言 详解如何删除有序数组中的重复项的文章就介绍到这了,更多相关C语言 有序数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
C++中string字符串分割函数split()的4种实现方法
最近笔试经常遇到需要对字符串进行快速分割的情景,下面这篇文章主要给大家介绍了关于C++中string字符串分割函数split()的4种实现方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-06-06Qt中关联容器QMap,QMultiMap,QHash,QMultiHash的使用
本文主要介绍了Qt中关联容器QMap,QMultiMap,QHash,QMultiHash的使用,这些关联容器在Qt中提供了灵活而强大的数据结构选项,根据具体的需求和使用场景,您可以选择适合的容器来存储和管理数据,感兴趣的可以了解一下2023-09-09
最新评论