欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

leetcode[160] Intersection of Two Linked Lis

系統(tǒng) 1737 0

那幾題要15刀才能測(cè)試的就先放著了。先吧可以在線測(cè)試的刷了。

這題是找到零個(gè)鏈表的相交的那個(gè)節(jié)點(diǎn)。如果沒(méi)有相交,那就返回NULL。

思路一:

如果有相交,那么他們相交點(diǎn)之后的節(jié)點(diǎn)肯定都是共有的,然后兩個(gè)鏈表有長(zhǎng)有短的話,就先把長(zhǎng)的讀到和短的一樣長(zhǎng),然后兩個(gè)人在同時(shí)走,走到第一個(gè)相同的點(diǎn)就是答案了。如果相同的點(diǎn)是NULL了,那就是沒(méi)有相交點(diǎn)。

      
        /*
      
      
        *

 * Definition for singly-linked list.

 * struct ListNode {

 *     int val;

 *     ListNode *next;

 *     ListNode(int x) : val(x), next(NULL) {}

 * };

 
      
      
        */
      
      
        class
      
      
         Solution {


      
      
        public
      
      
        :

    ListNode 
      
      *getIntersectionNode(ListNode *headA, ListNode *
      
        headB) {

        ListNode 
      
      *l1 = headA, *l2 =
      
         headB;

        
      
      
        if
      
       (!headA || !headB) 
      
        return
      
      
         NULL;

        
      
      
        int
      
       cnt1 = 
      
        0
      
      , cnt2 = 
      
        0
      
      
        ;

        
      
      
        while
      
      
        (l1)

        {

            cnt1
      
      ++; l1 = l1 ->
      
         next;

        }

        
      
      
        while
      
      
        (l2)

        {

            cnt2
      
      ++; l2 = l2 ->
      
         next;

        }

        
      
      
        if
      
       (cnt1 >
      
         cnt2)

        {

            l1 
      
      = headA; l2 =
      
         headB;

            
      
      
        int
      
       tmpcnt1 = cnt1 -
      
         cnt2;

            
      
      
        while
      
      (tmpcnt1-- > 
      
        0
      
      
        )

                l1 
      
      = l1 ->
      
         next;

        }

        
      
      
        else
      
      
        

        {

            l2 
      
      = headB; l1 =
      
         headA;

            
      
      
        int
      
       tmpcnt2 = cnt2 -
      
         cnt1;

            
      
      
        while
      
      (tmpcnt2-- > 
      
        0
      
      
        )

                l2 
      
      = l2 ->
      
         next;

        }

        
      
      
        while
      
      (l1 && l2 && l1 !=
      
         l2)

        {

            l1 
      
      = l1 ->
      
         next;

            l2 
      
      = l2 ->
      
         next;

        }

        
      
      
        if
      
       (l1 ==
      
         l2)

            
      
      
        return
      
      
         l1;

        
      
      
        return
      
      
         NULL;

    }

};
      
    

思路二:

因?yàn)閮蓚€(gè)鏈表長(zhǎng)度可能不一樣長(zhǎng),所以不能從第一次走一樣的距離判斷相交點(diǎn),但是??梢赃@樣,兩個(gè)鏈表同時(shí)走,走到末尾后,分別將指針跳到另一個(gè)鏈表的開頭,這樣,他們第一次相同的點(diǎn)就是答案了。

        
          /*
        
        
          *

 * Definition for singly-linked list.

 * struct ListNode {

 *     int val;

 *     ListNode *next;

 *     ListNode(int x) : val(x), next(NULL) {}

 * };

 
        
        
          */
        
        
          class
        
        
           Solution {


        
        
          public
        
        
          :

    ListNode 
        
        *getIntersectionNode(ListNode *headA, ListNode *
        
          headB) {

        ListNode 
        
        *l1 = headA, *l2 =
        
           headB;

        
        
        
          if
        
         (!headA || !headB) 
        
          return
        
        
           NULL;

        
        
        
          while
        
        (l1 &&
        
           l2) 

        {

            l1 
        
        = l1 ->
        
           next;

            l2 
        
        = l2 ->
        
           next;

        }

        

        
        
        
          if
        
         (!
        
          l1)

        {

            l1 
        
        =
        
           headB;

            
        
        
          while
        
        (l1 &&
        
           l2)

            {

                l1 
        
        = l1 ->
        
           next;

                l2 
        
        = l2 ->
        
           next;

            }

            l2 
        
        =
        
           headA;

            
        
        
          while
        
        (l1 && l2 && l1 !=
        
           l2)

            {

                l1 
        
        = l1 ->
        
           next;

                l2 
        
        = l2 ->
        
           next;

            }

        }

        

        
        
        
          else
        
        
          

        {

            l2 
        
        =
        
           headA;

            
        
        
          while
        
        (l1 &&
        
           l2)

            {

                l1 
        
        = l1 ->
        
           next;

                l2 
        
        = l2 ->
        
           next;

            }

            l1 
        
        =
        
           headB;

            
        
        
          while
        
        (l1 && l2 && l1 !=
        
           l2)

            {

                l1 
        
        = l1 ->
        
           next;

                l2 
        
        = l2 ->
        
           next;

            }

        }

        
        
        
          if
        
         (l1 !=
        
           l2)

            
        
        
          return
        
        
           NULL;

        
        
        
          return
        
        
           l1;

    }

};
        
      
View Code

?

leetcode[160] Intersection of Two Linked Lists


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!??!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 久久久久国产 | 欧美日韩亚洲国内综合网俺 | 亚洲视频一区二区 | jizzjizzjizzjizz国产| 污网站在线免费看 | 成人无码髙潮喷水A片 | 国产日韩精品一区 | 黄色小视频在线观看 | 色播在线播放 | 亚洲精品久久久蜜桃 | 欧洲男女下面进出的视频 | 色六月婷婷 | 欧美va在线视频 | 久久久久久久久99精品 | 国产农村妇女毛片精品久久麻豆 | 色精品一区二区三区 | 浮力影院国产第一页 | 人人搞人人干 | va在线 | 99久久精品费精品国产一区二区 | 国产视频在线看 | 国产成人精品一区二区三区视频 | 亚洲成人福利在线 | 国产精品成人在线观看 | 国产亚洲精品精品国产亚洲综合 | 精品在线不卡 | 影音av| 久操免费在线视频 | 亚洲日韩精品AV无码富二代 | 国产不卡一区 | 99久久精品国产片 | 国产99页| 国产精品久久久久免费 | 久章草影院 | 午夜影院试看五分钟 | wwwbnb89| 欧美全黄 | 欧美阿v天堂视频在99线 | 日韩精品影视 | 色综合久久手机在线 | 国产成人小视频在线观看 |