精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

數據結構與算法之鏈表相交,找交點

開發 前端 算法
給你兩個單鏈表的頭節點 headA 和 headB ,請你找出并返回兩個單鏈表相交的起始節點。如果兩個鏈表沒有交點,返回 null 。

[[441326]]

鏈表相交

力扣題目鏈接:https://leetcode-cn.com/problems/intersection-of-two-linked-lists-lcci

給你兩個單鏈表的頭節點 headA 和 headB ,請你找出并返回兩個單鏈表相交的起始節點。如果兩個鏈表沒有交點,返回 null 。

圖示兩個鏈表在節點 c1 開始相交:

題目數據 保證 整個鏈式結構中不存在環。

注意,函數返回結果后,鏈表必須 保持其原始結構 。

示例 1:

示例 2:

示例 3:

思路

簡單來說,就是求兩個鏈表交點節點的指針。這里同學們要注意,交點不是數值相等,而是指針相等。

為了方便舉例,假設節點元素數值相等,則節點指針相等。

看如下兩個鏈表,目前curA指向鏈表A的頭結點,curB指向鏈表B的頭結點:

我們求出兩個鏈表的長度,并求出兩個鏈表長度的差值,然后讓curA移動到,和curB 末尾對齊的位置,如圖: 

此時我們就可以比較curA和curB是否相同,如果不相同,同時向后移動curA和curB,如果遇到curA == curB,則找到交點。

否則循環退出返回空指針。

C++代碼如下:

  1. class Solution { 
  2. public
  3.     ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) { 
  4.         ListNode* curA = headA; 
  5.         ListNode* curB = headB; 
  6.         int lenA = 0, lenB = 0; 
  7.         while (curA != NULL) { // 求鏈表A的長度 
  8.             lenA++; 
  9.             curA = curA->next
  10.         } 
  11.         while (curB != NULL) { // 求鏈表B的長度 
  12.             lenB++; 
  13.             curB = curB->next
  14.         } 
  15.         curA = headA; 
  16.         curB = headB; 
  17.         // 讓curA為最長鏈表的頭,lenA為其長度 
  18.         if (lenB > lenA) { 
  19.             swap (lenA, lenB); 
  20.             swap (curA, curB); 
  21.         } 
  22.         // 求長度差 
  23.         int gap = lenA - lenB; 
  24.         // 讓curA和curB在同一起點上(末尾位置對齊) 
  25.         while (gap--) { 
  26.             curA = curA->next
  27.         } 
  28.         // 遍歷curA 和 curB,遇到相同則直接返回 
  29.         while (curA != NULL) { 
  30.             if (curA == curB) { 
  31.                 return curA; 
  32.             } 
  33.             curA = curA->next
  34.             curB = curB->next
  35.         } 
  36.         return NULL
  37.     } 
  38. }; 
  • 時間復雜度:
  • 空間復雜度:

其他語言版本

Java

  1. public class Solution { 
  2.     public ListNode getIntersectionNode(ListNode headA, ListNode headB) { 
  3.         ListNode curA = headA; 
  4.         ListNode curB = headB; 
  5.         int lenA = 0, lenB = 0; 
  6.         while (curA != null) { // 求鏈表A的長度 
  7.             lenA++; 
  8.             curA = curA.next
  9.         } 
  10.         while (curB != null) { // 求鏈表B的長度 
  11.             lenB++; 
  12.             curB = curB.next
  13.         } 
  14.         curA = headA; 
  15.         curB = headB; 
  16.         // 讓curA為最長鏈表的頭,lenA為其長度 
  17.         if (lenB > lenA) { 
  18.             //1. swap (lenA, lenB); 
  19.             int tmpLen = lenA; 
  20.             lenA = lenB; 
  21.             lenB = tmpLen; 
  22.             //2. swap (curA, curB); 
  23.             ListNode tmpNode = curA; 
  24.             curA = curB; 
  25.             curB = tmpNode; 
  26.         } 
  27.         // 求長度差 
  28.         int gap = lenA - lenB; 
  29.         // 讓curA和curB在同一起點上(末尾位置對齊) 
  30.         while (gap-- > 0) { 
  31.             curA = curA.next
  32.         } 
  33.         // 遍歷curA 和 curB,遇到相同則直接返回 
  34.         while (curA != null) { 
  35.             if (curA == curB) { 
  36.                 return curA; 
  37.             } 
  38.             curA = curA.next
  39.             curB = curB.next
  40.         } 
  41.         return null
  42.     } 
  43.  

Python

  1. class Solution: 
  2.     def getIntersectionNode(self, headA: ListNode, headB: ListNode) -> ListNode: 
  3.         ""
  4.         根據快慢法則,走的快的一定會追上走得慢的。 
  5.         在這道題里,有的鏈表短,他走完了就去走另一條鏈表,我們可以理解為走的快的指針。 
  6.  
  7.         那么,只要其中一個鏈表走完了,就去走另一條鏈表的路。如果有交點,他們最終一定會在同一個 
  8.         位置相遇 
  9.         ""
  10.         cur_a, cur_b = headA, headB     # 用兩個指針代替a和b 
  11.  
  12.  
  13.         while cur_a != cur_b: 
  14.             cur_a = cur_a.next if cur_a else headB      # 如果a走完了,那么就切換到b走 
  15.             cur_b = cur_b.next if cur_b else headA      # 同理,b走完了就切換到a 
  16.  
  17.         return cur_a 

Go

  1. func getIntersectionNode(headA, headB *ListNode) *ListNode { 
  2.     curA := headA 
  3.     curB := headB 
  4.     lenA, lenB := 0, 0 
  5.     // 求A,B的長度 
  6.     for curA != nil { 
  7.         curA = curA.Next 
  8.         lenA++ 
  9.     } 
  10.     for curB != nil { 
  11.         curB = curB.Next 
  12.         lenB++ 
  13.     } 
  14.     var step int 
  15.     var fast, slow *ListNode 
  16.     // 請求長度差,并且讓更長的鏈表先走相差的長度 
  17.     if lenA > lenB { 
  18.         step = lenA - lenB 
  19.         fast, slow = headA, headB 
  20.     } else { 
  21.         step = lenB - lenA 
  22.         fast, slow = headB, headA 
  23.     } 
  24.     for i:=0; i < step; i++ { 
  25.         fast = fast.Next 
  26.     } 
  27.     // 遍歷兩個鏈表遇到相同則跳出遍歷 
  28.     for fast != slow { 
  29.         fast = fast.Next 
  30.         slow = slow.Next 
  31.     } 
  32.     return fast 

javaScript

  1. var getListLen = function(head) { 
  2.     let len = 0, cur = head; 
  3.     while(cur) { 
  4.        len++; 
  5.        cur = cur.next
  6.     } 
  7.     return len; 
  8. var getIntersectionNode = function(headA, headB) { 
  9.     let curA = headA,curB = headB, 
  10.         lenA = getListLen(headA), 
  11.         lenB = getListLen(headB); 
  12.     if(lenA < lenB) { 
  13.         [curA, curB] = [curB, curA]; 
  14.         [lenA, lenB] = [lenB, lenA]; 
  15.     } 
  16.     let i = lenA - lenB; 
  17.     while(i-- > 0) { 
  18.         curA = curA.next 
  19.     } 
  20.     while(curA && curA !== curB) { 
  21.         curA = curA.next
  22.         curB = curB.next
  23.     } 
  24.     return curA; 
  25. }; 

 

責任編輯:姜華 來源: 代碼隨想錄
相關推薦

2021-01-28 07:33:34

JavaScript鏈表數據

2021-03-10 08:42:19

Java數據結構算法

2021-07-13 07:52:03

Python數據結構

2021-07-15 06:43:12

Python數據結構

2017-03-01 13:58:46

Python數據結構鏈表

2022-09-26 07:56:53

AVL算法二叉樹

2022-09-21 07:57:33

二叉搜索樹排序二叉樹

2020-10-30 09:56:59

Trie樹之美

2020-12-31 05:31:01

數據結構算法

2020-10-21 14:57:04

數據結構算法圖形

2012-02-02 10:21:05

單鏈表nexthead

2023-03-08 08:03:09

數據結構算法歸并排序

2020-10-20 08:14:08

算法與數據結構

2021-03-11 08:53:20

Java數據結構算法

2020-10-12 11:48:31

算法與數據結構

2022-01-18 19:13:52

背包問題數據結構算法

2023-10-27 07:04:20

2021-08-03 10:24:59

數據跳躍鏈表結構

2021-12-10 11:27:59

數據結構算法單調遞增的數字

2009-08-11 14:43:42

C#數據結構與算法
點贊
收藏

51CTO技術棧公眾號

亚洲一区二区三区成人在线视频精品| 日韩电影中文字幕在线观看| 中文精品一区二区三区| 国产不卡一区二区视频| 手机看片1024日韩| 日本欧美加勒比视频| 日韩在线精品视频| 国产午夜在线一区二区三区| 久久电影中文字幕| 麻豆高清免费国产一区| 欧美国产在线电影| 青青草视频成人| 国产亚洲字幕| 欧美性xxxxx极品| 丰满女人性猛交| 瑟瑟在线观看| 国产成人久久精品77777最新版本| 欧美亚洲激情视频| 久久国产精品国语对白| 亚洲瘦老头同性70tv| 欧美一区二区三区四区五区 | 色三级在线观看| 成人黄色小视频在线观看| 国产成人精品综合久久久| 欧美日韩在线视频免费| 欧洲乱码伦视频免费| 日韩手机在线导航| 五月婷婷六月合| 亚洲天堂资源| 亚洲一区二区三区四区的| 亚洲国产精品毛片| 亚洲 另类 春色 国产| 国产制服丝袜一区| 国产精品电影观看| 免费观看一区二区三区毛片| 91久久精品无嫩草影院| 在线视频综合导航| www.中文字幕在线| 久草在线视频福利| 亚洲欧美日韩久久| 一区二区不卡在线| 国产福利在线视频| 91欧美一区二区| 国产亚洲第一区| wwwav网站| 国产一区二区导航在线播放| 国产美女精品免费电影| wwwwww在线观看| 亚洲免费网站| 5278欧美一区二区三区| 欧美不卡视频在线观看| 欧美欧美全黄| 欧美精品在线免费| 国产这里有精品| 欧美/亚洲一区| 欧美成人午夜剧场免费观看| 精品人妻伦九区久久aaa片| 色呦哟—国产精品| 欧美久久久久久久久久| 日本一道在线观看| 久草免费在线| 亚洲视频免费在线| 中文字幕日韩精品久久| 日本精品一区二区三区在线播放| 国产精品私人影院| 一区二区免费在线观看| 蜜桃视频网站在线| 自拍偷拍国产精品| 春色成人在线视频| 亚洲精品网站在线| gogo大胆日本视频一区| 久久爱av电影| 狠狠狠综合7777久夜色撩人| 国产精品色哟哟网站| 日本福利视频导航| 日本三级在线观看网站| 久久网站最新地址| 五码日韩精品一区二区三区视频| 国产后入清纯学生妹| 高清不卡一二三区| 久久久久久九九九九| 免费成人av电影| 国产91富婆露脸刺激对白| 肥熟一91porny丨九色丨| 午夜视频在线播放| 中文字幕精品一区二区精品绿巨人| 亚洲精品国产一区| 日本在线视频网址| 欧美性xxxxx极品娇小| 日韩欧美国产片| 三级在线观看视频| 在线观看国产一区二区| 天天操精品视频| 日韩av影院| 精品国产一区二区三区久久狼黑人| 免费中文字幕在线| 99成人精品| 国产美女扒开尿口久久久| 亚洲不卡免费视频| 国产欧美日韩不卡免费| 日韩成人午夜影院| 最新欧美电影| 欧美哺乳videos| 白白色免费视频| 欧美a级一区| 国产成人精品最新| 精品国产av一区二区三区| 久久色.com| 精品一区二区三区无码视频| 亚洲高清黄色| 欧美精品一区二区三区在线| 久久久久亚洲AV成人无在| 激情av一区| 国产主播精品在线| 五月天婷婷激情网| 亚洲激情图片一区| 久久婷五月综合| 亚洲宅男网av| 久久久久久久999| 久久亚洲AV无码| 欧美日韩精品| 国产精品自拍偷拍视频| 视频一区 中文字幕| 亚洲欧美另类久久久精品2019| av免费在线播放网站| 中文字幕在线视频久| 日韩欧美在线1卡| 黄色av片三级三级三级免费看| 在线观看不卡| 99精品国产高清一区二区| 中文字幕在线视频区| 狠狠躁夜夜躁人人躁婷婷91 | 黄色国产一级视频| 91精品麻豆| 中文字幕在线亚洲| 欧美性猛交xxxx乱大交hd| 99精品久久久久久| 色欲色香天天天综合网www| 欧美日韩黄色| 欧美大胆在线视频| 99在线无码精品入口| 国产精品白丝在线| jizz欧美性11| 色琪琪久久se色| 国产精品自拍网| avav免费在线观看| 欧美天堂亚洲电影院在线播放| 免费观看av网站| 久久精品盗摄| 日韩av电影免费在线观看| 欧美精品总汇| 色哟哟网站入口亚洲精品| 最近中文字幕在线观看视频| 国产欧美精品一区二区色综合 | 99精品黄色片免费大全| 国产精品无码免费专区午夜| 大型av综合网站| 日韩的一区二区| 日韩欧美激情视频| 97久久久精品综合88久久| 一本久道高清无码视频| 鲁大师精品99久久久| 91高清免费视频| 色综合久久网女同蕾丝边| 五月天激情综合| 亚洲免费一级视频| 欧美残忍xxxx极端| 91深夜福利视频| 在线āv视频| 亚洲精品97久久| 黄色av一级片| 中文一区二区完整视频在线观看| jizz欧美性11| 国产精品第十页| 九色91视频| 国产精欧美一区二区三区蓝颜男同| 亚洲精品一二区| 亚洲精品一区二三区| 国产精品久久久久久久久快鸭 | 99精品欧美一区二区三区小说| 亚洲人精品午夜射精日韩| 女人丝袜激情亚洲| 国产一区二区在线免费视频| 色呦呦在线免费观看| 日韩av网址在线| 在线观看中文字幕码| 波多野结衣中文字幕一区| 欧美日韩在线中文| 婷婷久久一区| 韩国成人动漫在线观看| 日韩一区二区三区在线免费观看 | 激情偷乱视频一区二区三区| 激情五月婷婷六月| 成人av国产| 国产精品久久国产三级国电话系列| 欧美成人精品在线| 欧美色综合一区二区三区| 8x8x8国产精品| av黄色在线看| 亚洲久草在线视频| 国产精品成人一区二区三区电影毛片| 久久99久久久久久久久久久| 免费久久99精品国产自| 91麻豆精品| 欧美一级片免费在线| 国产原创在线观看| 亚洲视频在线看| 欧美一级淫片免费视频魅影视频| 欧美日精品一区视频| 日韩视频免费观看高清| 亚洲欧洲精品一区二区三区| aaaaaav| 国产在线视频精品一区| 熟女性饥渴一区二区三区| 一区二区电影在线观看| 成人看片人aa| 1769视频在线播放免费观看| 亚洲国产成人av在线| 亚洲天堂网视频| 欧美视频一二三| 久久婷婷一区二区| 亚洲色图欧美在线| 国产黄色录像视频| 久久综合一区二区| 欧美熟妇精品一区二区蜜桃视频| 精品亚洲国产成人av制服丝袜| 激情五月亚洲色图| 欧美理论在线播放| 精品综合在线| 国产一区调教| 成人h视频在线观看| 国产区一区二| 91美女片黄在线观| 欧美午夜三级| 久久精品国产免费观看| 国产爆初菊在线观看免费视频网站 | 97se亚洲国产一区二区三区| 国产欧美一区二区| 精品裸体bbb| 国产精品久久久久福利| 桃色av一区二区| 97国产真实伦对白精彩视频8| 天堂av最新在线| 欧美肥臀大乳一区二区免费视频| 国产网站在线免费观看| 久久久99久久精品女同性| 日本福利在线| 久久韩国免费视频| 韩国中文字幕在线| 久久国产精品亚洲| 在线三级中文| 欧美放荡办公室videos4k| 污污的网站在线看| 久久久久久久久国产精品| 丰满大乳少妇在线观看网站 | www.精品国产| 国产日韩欧美视频在线| 高清不卡一区| 99久久一区三区四区免费| 亚洲一区网址| 国产亚洲一区二区三区在线播放| 欧美三级午夜理伦三级小说| 免费在线观看一区二区| 精品视频免费在线观看| 亚洲欧美久久久久一区二区三区| 91偷拍一区二区三区精品| 午夜探花在线观看| 欧美日本二区| 日本www在线播放| 日韩av一级片| 超碰在线免费av| 成人av网站大全| 91视频免费观看网站| 国产精品视频yy9299一区| 日本黄色小说视频| 欧美日韩国产精品一区二区不卡中文| 六月丁香激情综合| 欧美日韩高清一区二区| 国产黄a三级三级看三级| 亚洲国产97在线精品一区| 黄色av免费在线观看| 欧美成人剧情片在线观看| 2021中文字幕在线| 国产精品电影网站| 国产午夜久久av| 久久综合色一本| 国产精品成人一区二区不卡| 无码人妻少妇伦在线电影| 久久一区二区三区超碰国产精品| 国产欧美一区二| 99精品久久99久久久久| 午夜国产小视频| 欧美日韩一区二区三区| 国产精品呻吟久久| 亚洲国产黄色片| 快射视频在线观看| 欧洲美女7788成人免费视频| 天堂久久一区| 九色综合婷婷综合| 亚洲电影在线一区二区三区| 91av资源网| 粉嫩在线一区二区三区视频| 精品一区二区三区蜜桃在线| 亚洲综合图片区| 亚洲精品国产精品乱码视色| 精品国精品国产尤物美女| 午夜视频在线| 欧美在线视频免费播放| 91大神精品| 伊人久久大香线蕉午夜av| 亚洲在线一区| 精品人妻在线视频| 国产伦精品一区二区三区免费迷 | 亚洲一区影音先锋| 中日精品一色哟哟| 亚洲国产中文字幕久久网| 成人毛片av在线| 国产日本欧美在线观看| 妖精一区二区三区精品视频| 欧美国产视频一区| 精品无码三级在线观看视频| 中文字幕在线观看免费高清| 亚洲成人激情av| www.蜜臀av| 久久久精品美女| 欧美黄色成人| 亚洲国产综合自拍| 久久综合图片| av中文字幕免费观看| 精品成人国产在线观看男人呻吟| 国产av无码专区亚洲av| 精品国产依人香蕉在线精品| 九九热这里有精品| 亚洲va韩国va欧美va精四季| 美女精品一区| 中文字幕一区二区三区人妻不卡| 亚洲午夜精品在线| 性中国古装videossex| 欧美成人亚洲成人| 国产精品亚洲一区二区在线观看 | 99re6在线精品视频免费播放| 亚洲一区中文字幕在线观看| 久久资源中文字幕| 激情五月俺来也| 国产精品国产自产拍在线| 一级一级黄色片| 在线日韩欧美视频| 久久69成人| 中文字幕久久综合| 久久成人羞羞网站| 一本一本久久a久久| 欧美日本在线视频| 黄网站免费在线观看| 91中文字幕一区| 欧美精品一区二区三区久久久竹菊| 超碰人人cao| 亚洲一区国产视频| 手机在线观看免费av| 26uuu久久噜噜噜噜| 国产乱码精品一区二区亚洲| 手机看片福利盒子久久| 国产精品乱码一区二区三区软件| 亚洲天堂男人网| 欧美大片大片在线播放| 好吊妞国产欧美日韩免费观看网站| 欧美成人高潮一二区在线看| 99国产欧美另类久久久精品| 9i精品福利一区二区三区| 色偷偷88888欧美精品久久久| 日韩成人视屏| 久激情内射婷内射蜜桃| 久久精品无码一区二区三区| 亚洲最新av网站| 欧美日本中文字幕| 日韩大胆成人| 一区二区三区视频在线观看免费| 中文字幕一区免费在线观看| 成人高潮片免费视频| 992tv成人免费影院| 欧美综合视频| 免费看三级黄色片| 欧美激情中文字幕| 国产免费av观看| 7777免费精品视频| 色777狠狠狠综合伊人| 26uuu国产| 色国产精品一区在线观看| 黄色片网站在线观看| 精品国产一区二区三区久久久久久| 日韩精品1区2区3区| 加勒比婷婷色综合久久| 日韩极品精品视频免费观看| 亚洲aⅴ网站| 美女福利视频在线| 亚洲欧洲一区二区在线播放| 熟妇人妻av无码一区二区三区| 国产精品尤物福利片在线观看| 亚洲三级视频| 精品国产视频在线观看| 亚洲精品99999|