亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

leetcode[160] Intersection of Two Linked Lis

系統 1925 0

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

這題是找到零個鏈表的相交的那個節點。如果沒有相交,那就返回NULL。

思路一:

如果有相交,那么他們相交點之后的節點肯定都是共有的,然后兩個鏈表有長有短的話,就先把長的讀到和短的一樣長,然后兩個人在同時走,走到第一個相同的點就是答案了。如果相同的點是NULL了,那就是沒有相交點。

      
        /*
      
      
        *

 * 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;

    }

};
      
    

思路二:

因為兩個鏈表長度可能不一樣長,所以不能從第一次走一樣的距離判斷相交點,但是。可以這樣,兩個鏈表同時走,走到末尾后,分別將指針跳到另一個鏈表的開頭,這樣,他們第一次相同的點就是答案了。

        
          /*
        
        
          *

 * 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


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天天干天天要 | 99视频久久精品久久 | 男人资源在线 | 黑人巨大vs日本妞 | 色拍拍欧美视频在线看 | 亚洲一区免费视频 | 人人干人人爱 | 成人免费视频在线看 | 日本一级爽爽爽爽 | 激情欧美一区二区三区中文字幕 | 国产亚洲精品激情都市 | 久久99久久精品97久久综合 | 妖精www视频在线观看高清 | 九九这里只精品视在线99 | 在线综合+亚洲+欧美中文字幕 | 婷婷六月激情在线综合激情 | 天天都色| 国产美女视频免费 | 亚洲 欧美 综合 | 色综合天天综合网亚洲 | 日韩狠狠操 | 亚洲国产欧美国产第一区二区三区 | 在线观看国产精品日本不卡网 | 久久久久久久国产精品 | h视频网站在线观看 | 狠狠做深爱婷婷久久一区 | 欧美成人看片黄a免费 | 日本亚洲免费 | 中文字幕国产在线观看 | 99这里有精品视频 | 狠狠色丁香婷婷综合最新地址 | 四虎影视永久免费观看网址 | 亚洲精品一区二区三区婷婷 | 久久久久久久国产免费看 | 精品国产看高清国产毛片 | 成年女人毛片免费播放视频m | 99久久综合狠狠综合久久一区 | 欧美视频一区二区 | 久久综合影院 | 日韩一区二区三区四区 | 欧美日韩免费 |