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

jake1036

面試100 35找出兩個(gè)鏈表的第一個(gè)共同節(jié)點(diǎn)

    面試100 35找出兩個(gè)鏈表的第一個(gè)共同節(jié)點(diǎn)

   一 問(wèn)題描述:
    找出兩個(gè)單鏈表中的第一個(gè)公共節(jié)點(diǎn)。
  解法1:  指針指向鏈表A的一個(gè)節(jié)點(diǎn),然后在鏈表B上循環(huán)后移,直到發(fā)現(xiàn)與A鏈相同的節(jié)點(diǎn),若是找不到,則A鏈后移。整個(gè)代碼的時(shí)間復(fù)雜度為o(mn)
  解法2:  我自己想到的一個(gè)辦法,先將鏈表A的每一個(gè)指針的地址。作為hash映射到hash表中,然后遍歷B鏈表,做同等的映射,直到第一次發(fā)現(xiàn)已經(jīng)在
                  hash表中存在的節(jié)點(diǎn)。即為所求。
  解法3: 最終的辦法,因?yàn)槭菃捂湵恚栽诘谝粋€(gè)共同的節(jié)點(diǎn)之后,其余所有的節(jié)點(diǎn)都是共同的,所以為Y型。
                   所以不同的節(jié)點(diǎn),只會(huì)在兩個(gè)鏈表的最前方。根據(jù)此點(diǎn),即可利用下面的小技巧,進(jìn)行解決,時(shí)間復(fù)雜度為o(n),但是需要兩次遍歷鏈表
                  求鏈表的長(zhǎng)度。
                  考慮A鏈表的長(zhǎng)度大于B鏈表,且長(zhǎng)出B鏈表l個(gè)節(jié)點(diǎn),那我們接下來(lái)就可以先遍歷A鏈表的l個(gè)節(jié)點(diǎn),然后即可以對(duì)鏈A和鏈B,一同向后移動(dòng),
                  直到發(fā)現(xiàn)兩者共同指向的節(jié)點(diǎn)地址相同,即找到了所求。
  二代碼示例
    

#include <iostream>
#include 
<vector>
#include 
<iterator>

  
using namespace std ;
  
  
  
struct ListNode
  
{
    ListNode 
* next ;
    
int data ;             
  }
 ;
  
  ListNode head1 ; 
//頭節(jié)點(diǎn)A
  ListNode head2 ; //頭節(jié)點(diǎn)B
  
  
const int N = 10 ;
 
  
void buildList( ListNode * h , vector <int> &v) //遍歷stl數(shù)組,依次取得數(shù)據(jù) 
  {
     vector
<int>::iterator iter = v.begin() ;  
     
for(;iter < v.end() ; iter++)
     
{
        ListNode  
* temp = (ListNode  *)malloc(sizeof(ListNode)) ; 
        temp
->data = *iter ;
        temp
->next = h->next ;  
        h
->next = temp ;
     }
    
  }

  
  
//建立共同的節(jié)點(diǎn) 
  void buildSameList( ListNode * h1 , ListNode * h2) //遍歷stl數(shù)組,依次取得數(shù)據(jù) 
  {
     ListNode  
* temp = (ListNode  *)malloc(sizeof(ListNode)) ; //先申請(qǐng)一個(gè)節(jié)點(diǎn) 
     temp->data = 3 ;
     temp
->next = h2->next ;  
     h2
->next = temp ;
     
     
//讓h2的next指針,指向h1 
     temp->next = h1->next->next->next->next->next ;
  }

  
 
  
int length(ListNode *  p)
  
{
    
int len = 0 ;
      
     
while(p)
     
{
       len
++ ;   
       p 
= p->next ;
             
     }
        
     
return len ;    
  }

  
  
void visit(ListNode *  p)
  
{
    
      
     
while(p)
     
{
       cout
<<p->data<<" " ;    
       p 
= p->next ;
             
     }
        
         
  }

  
   
void findsamenode(ListNode * longlist ,ListNode * shortlist , int distance) //先把長(zhǎng)的鏈表,向后遍歷distance距離,然后同時(shí)向后遍歷A和B 
   {                                                                           // 直到發(fā)現(xiàn)兩者的節(jié)點(diǎn)地址相同,即找到所求 
        while(distance)
         
{
           longlist 
= longlist->next ;
           distance
-- ;              
         }

        
        
while(longlist && shortlist)
        
{
          
if(longlist == shortlist) //應(yīng)該是指針?biāo)赶虻牡刂罚粗羔樀闹凳窍嗤?nbsp;
            {
              cout
<<longlist->data ;         
              
break ;           
            }
 
            longlist 
= longlist->next ;
            shortlist 
= shortlist->next ;                
        }

        
   }

   
  
  
  
int main()
  
{
    head1.next 
= 0 ;
    head1.data 
= 1;   
    head2.next 
= 0 ;
    head2.data 
= 1;     
      
    vector 
<int> v ;
    
for(int i = 0 ; i < N ;i++)  
      v.push_back(i) ;
      
    buildList(
&head1 , v) ; //建立1和2兩個(gè)單鏈表 
    buildSameList(&head1 , &head2 ) ; //對(duì)鏈表1和鏈表2建立共同的節(jié)點(diǎn) 
    visit(head1.next) ;              //遍歷打印鏈表1和鏈表2 
    cout<<endl ;
    visit(head2.next) ;
    cout
<<endl ;
    
    
int len1 = length(head1.next) ;   //獲取鏈表1和鏈表2的長(zhǎng)度 
    int len2 = length(head2.next) ;
    cout
<<len1<<" "<<len2<<endl;
    
    
    
if(len1 >= len2)
     findsamenode(head1.next , head2.next , len1
-len2) ;
    
else
     findsamenode(head2.next , head1.next , len2
-len1) ; 
    
    
    system(
"pause") ;   
    
return 0 ;    
  }

 

posted on 2011-05-22 11:18 kahn 閱讀(1612) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产在线视频| 久久九九电影| 一区二区三区在线免费观看| 欧美日韩亚洲一区在线观看| 久久亚洲精品欧美| 亚洲欧美日韩国产综合在线 | 亚洲女爱视频在线| 亚洲激情电影在线| 久久久久久穴| 午夜一区二区三视频在线观看| 亚洲精品在线看| 在线日韩日本国产亚洲| 国产日韩精品一区二区浪潮av| 欧美日韩伦理在线| 欧美高清视频免费观看| 裸体女人亚洲精品一区| 久久久精品欧美丰满| 亚洲欧美另类久久久精品2019| 99精品视频一区| 亚洲精品影视| 亚洲人午夜精品免费| 亚洲电影免费在线观看| 亚洲成人直播| 亚洲二区在线观看| 亚洲成色精品| 亚洲国产一区二区视频| 亚洲大片在线| 亚洲国产天堂久久综合网| 欧美激情一区二区| 亚洲成在线观看| 亚洲国产精品一区在线观看不卡 | 欧美精品在线一区| 欧美成人精品h版在线观看| 久久综合伊人77777麻豆| 久久久久久夜精品精品免费| 久久久午夜精品| 久久久一区二区三区| 久久综合伊人77777蜜臀| 巨乳诱惑日韩免费av| 免播放器亚洲一区| 欧美激情精品久久久久久大尺度| 欧美高清视频一二三区| 欧美日韩1234| 国产精品久久久久高潮| 国产日本亚洲高清| 精品成人国产| 亚洲精品乱码久久久久| 一本一道久久综合狠狠老精东影业| 在线一区二区三区四区| 亚洲男人的天堂在线aⅴ视频| 亚洲欧美日韩国产成人精品影院| 欧美一区二区三区在线观看| 久久久久久久网站| 亚洲成色精品| 一本一道久久综合狠狠老精东影业 | 亚洲中无吗在线| 欧美一区不卡| 免费观看成人| 欧美色中文字幕| 国产亚洲精品aa| 亚洲国产日韩欧美综合久久| 一区二区欧美在线| 欧美在线欧美在线| 欧美激情a∨在线视频播放| 日韩一级不卡| 欧美专区福利在线| 欧美精品粉嫩高潮一区二区| 国产精品久久久久久久午夜| 今天的高清视频免费播放成人| 亚洲精品黄色| 午夜日韩在线| 欧美国产日韩xxxxx| 一本色道久久综合精品竹菊| 久久成人免费视频| 欧美精品日韩三级| 国内精品亚洲| 亚洲午夜日本在线观看| 久久免费视频在线| 日韩亚洲在线| 久久婷婷久久一区二区三区| 欧美三日本三级少妇三2023| 一区在线视频观看| 亚洲一区中文字幕在线观看| 鲁大师影院一区二区三区| 亚洲精品乱码久久久久久黑人| 欧美一区二区三区久久精品| 欧美日韩国产欧| 在线观看日韩av电影| 亚洲女ⅴideoshd黑人| 亚洲第一精品在线| 欧美在线播放| 国产精品视频| 在线亚洲高清视频| 欧美黄色小视频| 久久精品一区四区| 国产精品亚洲综合色区韩国| 99人久久精品视频最新地址| 免费欧美日韩| 欧美一区二区三区免费观看视频 | 在线精品亚洲| 久久精品视频免费| 亚洲网友自拍| 欧美日韩在线一二三| 亚洲精品免费在线| 免费观看久久久4p| 久久爱91午夜羞羞| 国产欧美精品久久| 亚洲欧美精品在线观看| 亚洲精品视频免费观看| 欧美gay视频激情| 亚洲国产精品传媒在线观看| 久久久久久9999| 欧美亚洲三区| 国产欧美日本一区二区三区| 亚洲欧美日韩中文视频| 日韩亚洲不卡在线| 欧美日韩国产成人在线免费| 亚洲精品日日夜夜| 亚洲福利视频一区| 免费观看30秒视频久久| 亚洲福利视频在线| 欧美xx视频| 美女日韩欧美| 亚洲全部视频| 最新中文字幕亚洲| 欧美成人精品不卡视频在线观看 | 欧美在线高清| 午夜精品亚洲| 国产一区二区三区直播精品电影| 欧美在线一级va免费观看| 亚洲免费视频网站| 国产欧美日韩一区| 久久综合狠狠| 免费看精品久久片| 日韩午夜高潮| 在线视频精品一| 国产精品视频一二三| 久久av红桃一区二区小说| 欧美一级二级三级蜜桃| 好吊一区二区三区| 欧美福利一区二区| 欧美美女bb生活片| 亚洲中无吗在线| 亚洲欧美另类综合偷拍| 国产在线精品成人一区二区三区 | 99伊人成综合| 国产乱码精品一区二区三区av| 久久成人国产| 久久午夜精品| 99精品国产福利在线观看免费 | 狠狠色综合网站久久久久久久| 免费成人在线观看视频| 欧美国内亚洲| 西西人体一区二区| 久久久精品tv| 亚洲精品网站在线播放gif| 亚洲免费大片| 国产一区二区三区观看| 欧美韩日一区| 国产精品乱码人人做人人爱| 久久视频国产精品免费视频在线 | 亚洲精品国产日韩| 国产精品久久国产三级国电话系列 | 欧美激情综合亚洲一二区| 亚洲综合第一页| 久久精品视频一| 宅男噜噜噜66国产日韩在线观看| 亚洲一区免费| 亚洲国产综合在线| 亚洲深夜激情| 亚洲国产精品一区二区www在线| 一本大道久久a久久综合婷婷| 国产在线观看一区| 亚洲精品在线看| 国产夜色精品一区二区av| 亚洲激情电影在线| 国产一区av在线| 日韩一区二区免费看| 狠狠色伊人亚洲综合成人| 夜夜躁日日躁狠狠久久88av| 精品51国产黑色丝袜高跟鞋| 99热在这里有精品免费| **网站欧美大片在线观看| 亚洲天堂久久| 亚洲精品视频在线看| 欧美中在线观看| 亚洲欧美色婷婷| 欧美精品综合| 老鸭窝毛片一区二区三区| 国产精品免费网站| 欧美激情视频网站| 国产一区二区成人久久免费影院| 日韩视频在线一区二区三区| 亚洲国产精品成人综合色在线婷婷| 亚洲自拍偷拍色片视频| 99riav久久精品riav| 久久综合婷婷| 久久伊人免费视频| 国产三级精品在线不卡| 亚洲视频综合|