欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言?詳解如何刪除有序數組中的重復項

 更新時間:2022年03月29日 14:57:29   作者:許同學。。  
數組不擅長插入(添加)和刪除元素。數組的優(yōu)點在于它是連續(xù)的,所以查找數據速度很快。但這也是它的一個缺點。正因為它是連續(xù)的,所以當插入一個元素時,插入點后所有的元素全部都要向后移;而刪除一個元素時,刪除點后所有的元素全部都要向前移

刪除有序數組中的重復項Ⅰ

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為常數)

今天的算法題就分享到這里了,博主也會在后期更新更加優(yōu)質的博文,如果對你有幫助的話,可以給個關注,順便給個贊。

到此這篇關于C語言 詳解如何刪除有序數組中的重復項的文章就介紹到這了,更多相關C語言 有序數組內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論