欧美三区_成人在线免费观看视频_欧美极品少妇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)論
主站蜘蛛池模板: 成人午夜亚洲影视在线观看 | 日韩成人性视频 | 久久精品 | 国产免费观看视频 | 亚洲性猛交xx乱 | 国产精品视频免费观看 | 久久久久成人精品 | 国内自拍偷拍网 | 日本精品中文字幕有码 | 色综合天天综合网看在线影院 | 九九精品久久久久久噜噜 | 亚洲毛片无码专区亚洲A片 日本高清www午色夜黄 | 色久在线 | 国产一区在线免费 | 亚洲在线视频播放 | 久久国产精品超级碰碰热 | 亚洲国产欧美久久香综合 | free-porn-ok| 免费在线成人 | 国产一级免费在线视频 | 国产一级毛片在线看 | 日韩久久精品 | 色橹橹欧美在线观看视频高清免费 | 欧美成人精品一区二区三区 | 久久91 | 国产专区在线视频 | 国产精品乱码一区二三区小蝌蚪 | 久久免费看少妇高潮A片麻豆 | 免费一级片在线观看 | 国产精品爱久久久久久久 | 国产亚洲综合一区二区 | 婷婷国产精品 | 亚洲国产精品久久久久666 | 侮辱丰满美丽的人妻 | 91社区影院 | 亚洲第一区视频在线观看 | 麻豆一区二区99久久久久 | 国产99免费 | 成人片网址| 成人在线综合网 | 欧美乱强性伦xxxxx |