欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

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

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊: 次

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īng)排序的數(shù)組進行遍歷便可知道數(shù)組中重復(fù)的數(shù)字。

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

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

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

解法3:對于給定的數(shù)組進行重排。對于下標為i的元素:如果a[i] == i,掃描下一個元素;如果不相等將a[i]與a[a[i]]進行比較,若是相等則找到了一個重復(fù)的數(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ù)字轉(zhuǎn)字符串int2str的方法

欄    目:C語言

下一篇:C++ 通過指針實現(xiàn)多態(tài)實例詳解

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

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1678.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有