欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言找出數(shù)組中的特定元素的算法解析

 更新時(shí)間:2016年03月15日 17:44:04   作者:wuzhekai1985  
這篇文章主要介紹了C語(yǔ)言中找出數(shù)組中特定元素的算法解析,包括找出數(shù)組中兩個(gè)只出現(xiàn)一次的數(shù)字的方法,需要的朋友可以參考下

     問(wèn)題描述:一個(gè)int數(shù)組,里面數(shù)據(jù)無(wú)任何限制,要求求出所有這樣的數(shù)a[i],其左邊的數(shù)都小于等于它,右邊的數(shù)都大于等于它。能否只用一個(gè)額外數(shù)組和少量其它空間實(shí)現(xiàn)。
      思路:如果能用兩個(gè)輔助數(shù)組,那么相對(duì)來(lái)說(shuō)簡(jiǎn)單一點(diǎn),可定義數(shù)組Min和數(shù)組Max,其中Min[i]表示自a[i]之后的最小值(包括a[i]),Max[i]表示自a[i]之前元素的最大值。有了這兩個(gè)輔助數(shù)組后,對(duì)于a[i],如果它大于Max[i-1]并且小于Min[i+1],那么就符合要求。
      但是題目要求是只用一個(gè)額外數(shù)組,其實(shí)Max數(shù)組可以省去,完全可以邊判斷邊計(jì)算,這是因?yàn)镸ax[i]是自左往右計(jì)算的,而判斷時(shí)也是自左往右,兩個(gè)過(guò)程正好可以合起來(lái)。只需用一個(gè)變量Max保存一下當(dāng)前的最大值即可。下面給出兩種方法的代碼實(shí)現(xiàn)。
      參考代碼:

//函數(shù)功能 : 找元素 
//函數(shù)參數(shù) : pArray指向數(shù)組,len為數(shù)組的元素個(gè)數(shù) 
//返回值 : 無(wú) 
void FindElements_Solution1(int *pArray, int len) 
{ 
  if(pArray == NULL || len <= 0 ) 
    return ; 
 
  int *pMin = new int[len]; 
  int *pMax = new int[len]; 
  int i; 
 
  pMax[0] = pArray[0]; 
  for(i = 1; i < len; i++)    //計(jì)算自i往前最大值的輔助數(shù)組 
    pMax[i] = (pMax[i-1] >= pArray[i])? pMax[i-1]: pArray[i]; 
  pMin[len-1] = pArray[len-1]; 
  for(i = len - 2; i >= 0; i--) //計(jì)算自i開始最小值的輔助數(shù)組 
    pMin[i] = (pMin[i+1] <= pArray[i])? pMin[i+1]: pArray[i]; 
 
  if(pArray[0] <= pMin[0])   //檢查第1個(gè)元素是否滿足條件 
    cout<<pArray[0]<<' '; 
  for(i = 1; i < len - 1; i++) 
  { 
    if(pArray[i] >= pMax[i-1] && pArray[i] <=pMin[i+1]) //滿足這個(gè)關(guān)系式的元素符合要求 
      cout<<pArray[i]<<' '; 
  } 
  if(pArray[len-1] >= pMax[len-1]) //檢查第len個(gè)元素是否滿足條件 
    cout<<pArray[i]; 
  cout<<endl; 
 
  delete [] pMin; 
  delete [] pMax; 
  pMin = pMax = NULL; 
} 

void FindElements_Solution2(int *pArray, int len) 
{ 
  if(pArray == NULL || len <= 0 ) 
    return ; 
 
  int *pMin = new int[len]; 
  int Max; 
  int i; 
 
  Max = pArray[0]; 
  pMin[len-1] = pArray[len-1]; 
  for(i = len - 2; i >= 0; i--) //計(jì)算自i開始最小值的輔助數(shù)組 
    pMin[i] = (pMin[i+1] <= pArray[i])? pMin[i+1]: pArray[i]; 
 
  if(pArray[0] <= pMin[0])   //檢查第1個(gè)元素是否滿足條件 
    cout<<pArray[0]<<' '; 
 
  for(i = 1; i < len - 1; i++) 
  { 
    if(pArray[i] >= Max && pArray[i] <=pMin[i+1]) //滿足這個(gè)關(guān)系式的元素符合要求 
      cout<<pArray[i]<<' '; 
    Max = (Max < pArray[i])? pArray[i]: Max; //更新當(dāng)前最大值 
  } 
  if(pArray[len-1] >= Max) //檢查第len個(gè)元素是否滿足條件 
    cout<<pArray[i]; 
  cout<<endl; 
 
  delete [] pMin; 
  pMin = NULL; 
} 

找出數(shù)組中兩個(gè)只出現(xiàn)一次的數(shù)字(數(shù)組)
 問(wèn)題描述:一個(gè)整型數(shù)組里除了兩個(gè)數(shù)字之外,其他的數(shù)字都出現(xiàn)了兩次。請(qǐng)寫程序找出這兩個(gè)只出現(xiàn)一次的數(shù)字。要求時(shí)間復(fù)雜度是O(n),空間復(fù)雜度是O(1)。
     思路:如果只有一個(gè)數(shù)字只出現(xiàn)一次,而其他都出現(xiàn)兩次,則直接將所有數(shù)字做一次異或運(yùn)算即可,因?yàn)橄嗟鹊臄?shù)字異或一下結(jié)果為0。如果有兩個(gè)數(shù)字只出現(xiàn)一次,而其他數(shù)字出現(xiàn)了兩次。該怎么辦呢?《編程之美》一書提供了一種方法,即先將所有數(shù)字做一次異或運(yùn)算,得到一個(gè)數(shù)字,然后以該數(shù)字的某非0位作為過(guò)濾位,將數(shù)組分成兩個(gè)部分,此時(shí)只出現(xiàn)一次的數(shù)字會(huì)被分到不同的部分?,F(xiàn)在問(wèn)題就轉(zhuǎn)為只出現(xiàn)一次的情況,對(duì)每部分分別做異或運(yùn)算即可。
     參考代碼:

//函數(shù)功能 : 找出數(shù)組中兩個(gè)只出現(xiàn)一次的數(shù)字 
//函數(shù)參數(shù) : arr為源數(shù)組,len為數(shù)組元素個(gè)數(shù),result用來(lái)存放結(jié)果  
//返回值 :  無(wú) 
void FindIsolateTwo(int *arr, int len, int *result) 
{ 
  int i, all = 0, flag = 1; 
 
  for(i = 0; i < len ; i++) //所有數(shù)異或 
    all ^= arr[i]; 
 
  while(!(all&flag)) //尋找過(guò)濾位 
    flag <<= 1; 
 
  result[0] = result[1] = 0; 
  for(i = 0; i < len; i++) //利用過(guò)濾位區(qū)分 
  { 
    if(flag&arr[i]) 
      result[0] ^= arr[i]; 
    else 
      result[1] ^= arr[i]; 
  } 
} 

相關(guān)文章

  • 淺談C++ 基類指針和子類指針的相互賦值

    淺談C++ 基類指針和子類指針的相互賦值

    下面小編就為大家?guī)?lái)一篇淺談C++ 基類指針和子類指針的相互賦值。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • 一篇文章帶你了解C語(yǔ)言函數(shù)的可重入性

    一篇文章帶你了解C語(yǔ)言函數(shù)的可重入性

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言函數(shù)的可重入性,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 用C++實(shí)現(xiàn)隊(duì)列的程序代碼

    用C++實(shí)現(xiàn)隊(duì)列的程序代碼

    本篇文章是對(duì)使用C++實(shí)現(xiàn)隊(duì)列的程序代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 聊聊C++ 運(yùn)算符重載知識(shí)

    聊聊C++ 運(yùn)算符重載知識(shí)

    運(yùn)算符重載是一種形式的C++多態(tài),重載運(yùn)算符可以使代碼看起來(lái)更加自然,下面通過(guò)例子介紹下C++ 運(yùn)算符重載知識(shí),感興趣的朋友一起看看吧
    2021-11-11
  • C++ LeetCode300最長(zhǎng)遞增子序列

    C++ LeetCode300最長(zhǎng)遞增子序列

    這篇文章主要為大家介紹了C++ LeetCode300最長(zhǎng)遞增子序列示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • C++基礎(chǔ)入門教程(八):函數(shù)指針

    C++基礎(chǔ)入門教程(八):函數(shù)指針

    這篇文章主要介紹了C++基礎(chǔ)入門教程(八):函數(shù)指針,本文講解了函數(shù)原型和函數(shù)定義、const限定符與指針、函數(shù)的指針參數(shù)、為什么要使用指針參數(shù)等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • 利用Matlab實(shí)現(xiàn)迭代適應(yīng)點(diǎn)算法

    利用Matlab實(shí)現(xiàn)迭代適應(yīng)點(diǎn)算法

    道格拉斯-普克算法(Douglas–Peucker?algorithm,亦稱為拉默-道格拉斯-普克算法、迭代適應(yīng)點(diǎn)算法、分裂與合并算法)是將曲線近似表示為一系列點(diǎn),并減少點(diǎn)的數(shù)量的一種算法。本文將利用Matlab實(shí)現(xiàn)這一算法,需要的可以參考一下
    2022-04-04
  • C++?手?jǐn)]簡(jiǎn)易服務(wù)器

    C++?手?jǐn)]簡(jiǎn)易服務(wù)器

    本文主要介紹了C++?手?jǐn)]簡(jiǎn)易服務(wù)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 淺析c與c++中struct的區(qū)別

    淺析c與c++中struct的區(qū)別

    c與c++中struct的區(qū)別你是否了解,下面小編就詳細(xì)的為大家介紹一下
    2013-07-07
  • c++實(shí)現(xiàn)逐行讀取配置文件寫入內(nèi)存的示例

    c++實(shí)現(xiàn)逐行讀取配置文件寫入內(nèi)存的示例

    這篇文章主要介紹了c++實(shí)現(xiàn)逐行讀取配置文件寫入內(nèi)存的示例,需要的朋友可以參考下
    2014-05-05

最新評(píng)論