国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C語言 數(shù)組中重復(fù)的數(shù)字分析及方法

2020-05-23 13:48:52
字體:
供稿:網(wǎng)友

C語言 數(shù)組中重復(fù)的數(shù)字解決方法:

題目:在一個長度為n的數(shù)組里的所有數(shù)字都在0-n-1的 范圍內(nèi)。數(shù)組中某些數(shù)字是重復(fù)的,但是不知道有幾個數(shù)字重復(fù)了,也不知道每個數(shù)字重復(fù)了幾次。請找出數(shù)組中任意一個重復(fù)的數(shù)字。例如,如果輸入長度為7的數(shù)組{2,3,1,0,2,5,3},那么對應(yīng)的輸出是重復(fù)的數(shù)字2或者3.

解法1:對于數(shù)組進(jìn)行排序,之后對于已經(jīng)排序的數(shù)組進(jìn)行遍歷便可知道數(shù)組中重復(fù)的數(shù)字。

時間復(fù)雜度;O(nlogn);

解法2:建立一個大小為O(N)的哈希表,遍歷數(shù)組中的元素并判斷是否存在于哈希表中。若不存在于哈希表中,將這個元素加入哈希表之中并且繼續(xù)掃描,若這個元素存在于哈希表中,則:找到了數(shù)組中重復(fù)的一個數(shù)字;

時間復(fù)雜度:O(N),空間復(fù)雜度:O(N);

解法3:對于給定的數(shù)組進(jìn)行重排。對于下標(biāo)為i的元素:如果a[i] == i,掃描下一個元素;如果不相等將a[i]與a[a[i]]進(jìn)行比較,若是相等則找到了一個重復(fù)的數(shù)字,若沒有,那么對于數(shù)字進(jìn)行交換,依次進(jìn)行。

C語言,數(shù)組中重復(fù)的數(shù)字,C數(shù)組中重復(fù)的數(shù)字解決辦法

 

int DuplicateInArray(int arr[],int size) {   int i=0;   while(i<size)   {     if(arr[i] == i)       ++i;     else     {       if(arr[i] != arr[arr[i]])       {swap(arr[i],arr[arr[i]]);}       else       {return arr[i];}     }   }   return -1; } 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 彭州市| 永州市| 太康县| 湘潭市| 新民市| 无为县| 青浦区| 西峡县| 平泉县| 介休市| 措勤县| 牟定县| 山丹县| 邳州市| 澎湖县| 图木舒克市| 清水县| 寿阳县| 莲花县| 九江市| 清镇市| 安西县| 花莲县| 阜康市| 正镶白旗| 建宁县| 陈巴尔虎旗| 高唐县| 南江县| 秦安县| 原阳县| 莒南县| 溧水县| 华坪县| 双鸭山市| 宽甸| 高陵县| 南溪县| 精河县| 丹巴县| 博兴县|