题解 | #序列中删除指定数字#

序列中整数去重

http://www.nowcoder.com/practice/6564a2f6e70f4153ad1ffd58b2b28490

写复杂了,评论区的大神写的真好,直接从输入那里做文章,省下好多功夫

#include<stdio.h>

int main()
{
    int n = 0, i = 0,j=0;
    int arr[50] = { 0 };
    scanf("%d", &n);
    for (i = 0; i < n; i++)
    {
        scanf("%d", &arr[i]);
    }
    for (i = 0; i < n; i++)
    {
        //每一个数字
        for (j = i+1; j < n; j++)
        {
            //和自身以外的数字进行比较
            if (arr[i] == arr[j])
            {
                //有重复,数组后面的整体向前提一位
                for (int k = 1; k < n-j; k++)
                    arr[j+k-1] = arr[k+j];
                j =j-1;
                n--;
            }
        }
        
    }
    for (int j = 0; j < n; j++)
        printf("%d ", arr[j]);
    return 0;
}
全部评论

相关推荐

码客明:我教你个方法,你和你室友沟通一下告知他这个事情。然后就说导员问我就说,室友已经和导员提前沟通了。最后被查到你就说室友和我说了他已经和你沟通好了我没想到他是骗我的呀!把责任都甩给你室友,当然你出去实习的室友也肯定愿意承担这个责任。
点赞 评论 收藏
分享
牛客52338264...:我也专升本 别写专科了 只写本科 有问再说 没问都不要提专科经历, 然后赶紧去学一个项目,把这个项目包装成实习经验 再学一个项目当做项目经验
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务