C語言 數(shù)組中重復的數(shù)字分析及方法
C語言 數(shù)組中重復的數(shù)字解決方法:
題目:在一個長度為n的數(shù)組里的所有數(shù)字都在0-n-1的 范圍內。數(shù)組中某些數(shù)字是重復的,但是不知道有幾個數(shù)字重復了,也不知道每個數(shù)字重復了幾次。請找出數(shù)組中任意一個重復的數(shù)字。例如,如果輸入長度為7的數(shù)組{2,3,1,0,2,5,3},那么對應的輸出是重復的數(shù)字2或者3.
解法1:對于數(shù)組進行排序,之后對于已經排序的數(shù)組進行遍歷便可知道數(shù)組中重復的數(shù)字。
時間復雜度;O(nlogn);
解法2:建立一個大小為O(N)的哈希表,遍歷數(shù)組中的元素并判斷是否存在于哈希表中。若不存在于哈希表中,將這個元素加入哈希表之中并且繼續(xù)掃描,若這個元素存在于哈希表中,則:找到了數(shù)組中重復的一個數(shù)字;
時間復雜度:O(N),空間復雜度:O(N);
解法3:對于給定的數(shù)組進行重排。對于下標為i的元素:如果a[i] == i,掃描下一個元素;如果不相等將a[i]與a[a[i]]進行比較,若是相等則找到了一個重復的數(shù)字,若沒有,那么對于數(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; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
上一篇:高效實現(xiàn)整型數(shù)字轉字符串int2str的方法
欄 目:C語言
下一篇:C++ 通過指針實現(xiàn)多態(tài)實例詳解
本文標題:C語言 數(shù)組中重復的數(shù)字分析及方法
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1678.html
您可能感興趣的文章
- 04-02c語言函數(shù)調用后清空內存 c語言調用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對數(shù)怎么表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求階乘


閱讀排行
本欄相關
- 04-02c語言函數(shù)調用后清空內存 c語言調用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求
隨機閱讀
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實例總結
- 08-05DEDE織夢data目錄下的sessions文件夾有什