217. Contains Duplicate(C语言)

一个数组,如果有重复的数就返回true,都不相同就返回false

好不容易调好了,超时,网上都说用哈希,map什么的,找了半天都是java。。。。

下面是我那个O(n^2)超时的程序,先冒泡升序排序再两两比较

bool containsDuplicate(int* nums, int numsSize) {
    int flag = 0,temp=0;
    if(numsSize==1||numsSize==0){
        flag=0;
    }else{
        for(int j=0;j<numsSize;j++){
            for(int i=0;i<numsSize-1;i++){
                if(nums[i]>nums[i+1]){
                    temp=nums[i+1];
                    nums[i+1]=nums[i];
                    nums[i]=temp;
                }
            }
        }
        for(int i=0;i<numsSize;i++){
            if(nums[i]==nums[i+1]){
                flag=1;
                break;
            }
        }
    }
        
    return flag;
}

柏宁提供了新思路

先遍历一遍,寻找给出数组的最小值和最大值

建立一个新的数组,从最小值到最大值那么长

让给定的数组的值对应到新的数组里

再遍历一遍新的数组,如果〉1说明有重复的,如果都《1,说明没有重复的

bool containsDuplicate(int* nums, int numsSize) {
    int i=0;
    int max=0,min=0;
    int bufsize=0;
    int *buf;
    int temp=0;
    
    if(numsSize<2){
        return false;
    }
    
    max=nums[0];
    min=nums[0];
    //找最大值和最小值
    for(i=0;i<numsSize;i++){
        if(nums[i]>max){
            max=nums[i];
        }
        if(nums[i]<min){
            min=nums[i];
        }
    }
    //新建数组
    bufsize=max-min+1;
    buf=(int *)malloc(bufsize*sizeof(int));
    memset(buf,0,bufsize*sizeof(int));
    
    for(i=0;i<numsSize;i++){
        temp=nums[i]-min;
        if(buf[temp]==0){
            buf[temp]=1;
        }else{
            return true;//如果nums[temp]!=0说明已经有一个也就说重复了
        }
    }
    
    return false;
}

memset这里百度了一下


因为我申请的是int,长度是4字节,所以后面要写成bufsize*sizeof(int)或者bufsize*4

伯宁说申请成char类型的数组就行,是1字节,而且后面是下标,值就0,1用不了那么多字节

不管了土豪



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值