C語言?詳解如何刪除有序數(shù)組中的重復項
刪除有序數(shù)組中的重復項Ⅰ


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.思考
?如果給你一個無序的數(shù)組,去除重復的元素,該如何設計程序?
刪除有序數(shù)組中的重復項Ⅱ


a.思路
?定義變量 int dest=0,cur=1,flag=1(表示0到dest,nums[dest]只出現(xiàn)過一次)。
?比較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.思考
?如果給定一個有序數(shù)組,刪除重復出現(xiàn)的元素,使每個元素最多出現(xiàn)k次 ,返回刪除后數(shù)組的新長度,該如何設計程序?(k為常數(shù))
今天的算法題就分享到這里了,博主也會在后期更新更加優(yōu)質的博文,如果對你有幫助的話,可以給個關注,順便給個贊。
到此這篇關于C語言 詳解如何刪除有序數(shù)組中的重復項的文章就介紹到這了,更多相關C語言 有序數(shù)組內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C++ 模擬實現(xiàn)list(迭代器)實現(xiàn)代碼
這篇文章主要介紹了C++ 模擬實現(xiàn)list(迭代器)實現(xiàn)代碼的相關資料,需要的朋友可以參考下2017-05-05
深入理解C++中的new/delete和malloc/free動態(tài)內存管理及區(qū)別介紹
這篇文章主要介紹了深入理解C++中的new/delete和malloc/free動態(tài)內存管理,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
C語言數(shù)據(jù)結構單鏈表接口函數(shù)全面講解教程
這篇文章主要為大家介紹了C語言數(shù)據(jù)結構單鏈表所有接口函數(shù)的全面講解教程,有需要朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2021-10-10

