欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C语言 详解如何删除有序数组中的重复项

时间:2022-10-28 09:52:48|栏目: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++之BOOST字符串查找示例

栏    目:C代码

下一篇:CFileDialog设置多选的问题解决

本文标题:C语言 详解如何删除有序数组中的重复项

本文地址:http://www.codeinn.net/misctech/217492.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有