一个数组,如果有重复的数就返回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用不了那么多字节
不管了土豪
