青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

jake1036

面試100 34找出數組中唯一出現一次的兩個數字

 面試100  34找出數組中唯一出現一次的兩個數字

 一問題描述
    一個數組中,存在兩個只出現一次的數字,其余的數字均出現兩次。要求在時間復雜度o(n),空間復雜度為o(1)的情況下找出這兩個數字。
 
二 問題分析
     此題實際考察了,對位操作的理解。首先進行簡化,考慮只有一個數組中,只存在出現了一次的一個數字,其余數字在數組中出現兩次,試
     找出這個數字。

 三 解決方案
    首先 回憶 異或操作,任意數字與自身相異或,結果都為0.
   還有一個重要的性質,即任何元素與0相異或,結果都為元素自身。
  
   解決方案:
  1   從數組的起始位置開始,對元素執行異或操作,則最后的結果,即為此只出現了一次的元素。
 
  2  題目中,數組中存在兩個不同的元素,若是能仿造上述的解決方案,將兩個元素分別放置在兩個數組中,然后分別對每個數組進行異或操作,
     則所求異或結果即為所求。
 
  3  首先對原數組進行全部元素的異或,得到一個必然不為0的結果,然后判斷該結果的2進制數字中,為1的最低的一位。
      然后根據此位是否為1 ,可以把原數組分為兩組。則兩個不同的元素,必然分別在這兩個數組中。
 4  然后對兩個數組,進行異或操作,即可得到所求。

 四 代碼示例
     

#include <iostream>
  
using namespace std ;
  
const int N = 10 ;
  
  
int getSingle(int * a) //獲取全部元素的異或結果 
  {
      
if(!a)
        
return -1;
        
     
int sum = a[0] ; 
     
     
for(int i = 1; i < N; i++)
       sum 
^= a[i] ;
       
     
return sum ;   
  }

  
  
  
int getTwo(int * a ,int & one , int & two , int sum) //求數組中兩個不同的元素 
  {
      unsigned 
int flag = 1;
      
while(flag) //求異或結果,最低的為1的二進制位,根據此位是否為1,將元素分為兩組,兩個不同的元素,在此位必然,一個為1,一個為0 
      {
        
if(flag&sum)
           
break;
        flag 
= flag << 1 ;        
      }

      
//下面將flag與每個元素相求與,根絕結果是否為1,將其化為兩個數組
      
//分別計算每個數組的異或結果,并將結果,存儲分別存儲在one和two中。
      one = two = 0 ;//0與任何數異或都為其自身,所以初始化的時候,應該初始化為0 
      for(int i = 0 ; i < N ;i++ )
      
{
        
if(a[i] & flag) 
        
{
                one 
^= a[i] ;
        }

        
else
        
{
             two 
^= a[i] ;
        }
        
      }

      
  }

  
  
int main()
  
{
      
int a[N] = {3 , 5 ,8 , 8 , 5 , 3 ,1 ,4 ,4,10} ;   
      
int single = getSingle(a) ;
      
int one = 0 ;
      
int two  = 0;
      getTwo(a ,one , two ,single) ;
      cout
<<single<<" "<<one<<" "<<two<<endl ;
     system(
"pause") ;
     
return 0 ;    
  }









 

 

posted on 2011-05-21 21:20 kahn 閱讀(1395) 評論(2)  編輯 收藏 引用 所屬分類: 算法相關

Feedback

# re: 面試100 34找出數組中唯一出現一次的兩個數字 2011-05-22 17:49 jince

解決方案說清楚一點,誰和誰異或?什么兩個數組,這能看么?大半在猜測你的說的話!  回復  更多評論   

# re: 面試100 34找出數組中唯一出現一次的兩個數字 2011-08-16 16:14 aa

@jince
這還要說么?  回復  更多評論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲麻豆一区| 韩国福利一区| 性欧美videos另类喷潮| 亚洲一区二区三区三| 亚洲一区中文字幕在线观看| 亚洲一区二区三区成人在线视频精品 | 亚洲国产精品ⅴa在线观看| 国产一区二区日韩| 一区二区亚洲欧洲国产日韩| 亚洲国产婷婷| 洋洋av久久久久久久一区| 亚洲午夜一区二区三区| 欧美一区免费视频| 美女尤物久久精品| 亚洲福利在线视频| 亚洲乱码久久| 久久成年人视频| 欧美日韩成人综合在线一区二区 | 在线视频你懂得一区| 亚洲主播在线观看| 久久综合给合久久狠狠色 | 欧美调教vk| 国产一区清纯| 亚洲最新中文字幕| 久久免费高清视频| 99riav1国产精品视频| 小黄鸭视频精品导航| 欧美电影专区| 国内精品久久久久影院优| 999在线观看精品免费不卡网站| 久久成人一区| 妖精视频成人观看www| 久久久亚洲精品一区二区三区 | 极品av少妇一区二区| 99综合视频| 噜噜噜噜噜久久久久久91| 99re6热在线精品视频播放速度| 久久久精品国产免费观看同学| 欧美日韩在线播| 亚洲激情综合| 久热爱精品视频线路一| 中文国产成人精品| 欧美日韩精品二区| 亚洲日本成人网| 免费成人黄色片| 欧美在线亚洲综合一区| 国产嫩草影院久久久久| 亚洲性感美女99在线| 最新热久久免费视频| 久久亚洲一区二区| 狠狠干成人综合网| 久久久久久久久久久久久9999 | 亚洲黄色一区| 免费av成人在线| 精品成人一区二区三区四区| 欧美资源在线| 午夜精品久久久久久久99水蜜桃| 国产精品vip| 亚洲男女自偷自拍| 一区二区欧美在线| 国产精品美女| 欧美专区福利在线| 欧美诱惑福利视频| 韩国av一区二区三区在线观看| 久久嫩草精品久久久精品| 久久精品二区亚洲w码| 国产一区深夜福利| 看片网站欧美日韩| 国产午夜亚洲精品羞羞网站 | 亚洲一区二区三区免费观看| 欧美人与性禽动交情品 | 久久久亚洲综合| 在线日韩中文| 亚洲国产精品va在线看黑人动漫| 女仆av观看一区| 亚洲美女区一区| 日韩午夜精品视频| 国产精品一区二区在线观看| 久久久久久精| 欧美jizzhd精品欧美巨大免费| 日韩视频一区二区在线观看 | 欧美自拍偷拍| 亚洲国产福利在线| 亚洲人精品午夜在线观看| 欧美色图五月天| 小辣椒精品导航| 久久精品官网| aa级大片欧美| 午夜一区二区三区不卡视频| 亚洲第一天堂av| 日韩一区二区免费高清| 国产女同一区二区| 免费亚洲电影| 国产精品成人一区二区艾草| 久久久噜噜噜久久| 欧美精品一区二区高清在线观看| 性高湖久久久久久久久| 你懂的一区二区| 欧美一区二区三区视频免费| 久久在线视频在线| 午夜在线观看欧美| 久久亚洲色图| 亚洲欧美一区二区视频| 欧美ed2k| 久久综合999| 国产精品播放| 亚洲国产精品久久久久秋霞影院| 国产精品视频在线观看| 亚洲国产1区| 国产一区欧美日韩| 亚洲色图自拍| 一本久久综合| 欧美国产日韩视频| 久久久国产午夜精品| 欧美日韩中文字幕在线视频| 欧美成人一品| 激情五月婷婷综合| 亚洲欧美日韩网| 亚洲欧美韩国| 欧美视频一区| 久久婷婷综合激情| 亚洲午夜久久久| 欧美成人第一页| 久热精品视频在线免费观看 | 亚洲国产精品一区制服丝袜| 亚洲欧美在线免费| 在线一区二区三区做爰视频网站 | 亚洲在线播放| 一区二区三区偷拍| 欧美精品一区二区三区久久久竹菊| 久久尤物电影视频在线观看| 国产美女精品视频| 亚洲女优在线| 欧美中文字幕视频| 国产女精品视频网站免费| 亚洲免费影视| 久久精品国产亚洲一区二区三区| 国产女人水真多18毛片18精品视频| 亚洲字幕一区二区| 欧美一区不卡| 国产一区二区成人| 性xx色xx综合久久久xx| 久久精品国产久精国产爱| 国产午夜精品久久久| 久久国产精品久久久久久电车| 久久久久久一区二区| 国产在线乱码一区二区三区| 久久精品卡一| 亚洲国产高清aⅴ视频| 亚洲欧洲综合| 欧美色中文字幕| 亚洲欧美在线另类| 免费成人av在线看| 日韩亚洲视频| 国产精品女人久久久久久| 欧美亚洲三区| 欧美福利一区| 亚洲一区二区成人在线观看| 国产伦精品一区二区三区四区免费| 久久爱www久久做| 欧美国产亚洲另类动漫| 中文欧美在线视频| 国产一区999| 欧美精品导航| 欧美一区二区在线| 亚洲国产综合91精品麻豆| 一区二区三区四区五区在线| 国产一区91精品张津瑜| 欧美刺激性大交免费视频| 一区二区三区不卡视频在线观看| 久久国产加勒比精品无码| 亚洲第一二三四五区| 欧美视频在线一区二区三区| 久久精品亚洲一区二区| 一本色道久久综合亚洲精品婷婷| 久久精品日产第一区二区| 亚洲精品无人区| 国内久久视频| 国产精品久久二区| 麻豆成人av| 亚洲欧美乱综合| 欧美国产亚洲另类动漫| 午夜精品成人在线视频| 亚洲精品激情| 国内视频一区| 国产精品理论片| 欧美高清自拍一区| 欧美在线一二三| 亚洲线精品一区二区三区八戒| 欧美va亚洲va日韩∨a综合色| 久久精品av麻豆的观看方式| 亚洲国产cao| 欧美日韩在线影院| 久久伊人一区二区| 亚洲一区二区在| 亚洲精品在线看| 欧美电影资源| 久久综合精品一区| 欧美一区二区三区在线观看| 亚洲一区二区三区国产|