亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言?詳解如何刪除有序數(shù)組中的重復(fù)項(xiàng)

 更新時(shí)間:2022年03月29日 14:57:29   作者:許同學(xué)。。  
數(shù)組不擅長(zhǎng)插入(添加)和刪除元素。數(shù)組的優(yōu)點(diǎn)在于它是連續(xù)的,所以查找數(shù)據(jù)速度很快。但這也是它的一個(gè)缺點(diǎn)。正因?yàn)樗沁B續(xù)的,所以當(dāng)插入一個(gè)元素時(shí),插入點(diǎn)后所有的元素全部都要向后移;而刪除一個(gè)元素時(shí),刪除點(diǎn)后所有的元素全部都要向前移

刪除有序數(shù)組中的重復(fù)項(xiàng)Ⅰ

a.思路

?定義變量 int dest=0,cur=1,nums[cur]與nums[dest]逐一比較。

?nums[cur]!=nums[dest],將nums[cur]放入dest下一個(gè)位置,更新dest。

?nums[cur]!=nums[dest],cur移動(dòng)。

?cur==numsSize,結(jié)束。返回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.思考

?如果給你一個(gè)無(wú)序的數(shù)組,去除重復(fù)的元素,該如何設(shè)計(jì)程序?

刪除有序數(shù)組中的重復(fù)項(xiàng)Ⅱ

a.思路

?定義變量 int dest=0,cur=1,flag=1(表示0到dest,nums[dest]只出現(xiàn)過(guò)一次)。

?比較nums[cur]與nums[dest]。

?nums[cur]!=nums[dest],將nums[cur]放入dest下一個(gè)位置,++dest,更新flag(flag=1)。

?nums[cur]==nums[dest],如果dest所對(duì)應(yīng)的flag為1,可將nums[cur]放入dest下一個(gè)位置,++dest, ++flag。如果dest所對(duì)應(yīng)的flag為2,只移動(dòng)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.思考

?如果給定一個(gè)有序數(shù)組,刪除重復(fù)出現(xiàn)的元素,使每個(gè)元素最多出現(xiàn)k次 ,返回刪除后數(shù)組的新長(zhǎng)度,該如何設(shè)計(jì)程序?(k為常數(shù))

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

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

相關(guān)文章

最新評(píng)論