日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

相交链表解法一

發布時間:2025/3/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 相交链表解法一 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

編寫一個程序,找到兩個單鏈表相交的起始節點。

如下面的兩個鏈表:

在節點 c1 開始相交。
示例 1:

輸入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3
輸出:Reference of the node with value = 8
輸入解釋:相交節點的值為 8 (注意,如果兩個列表相交則不能為 0)。從各自的表頭開始算起,鏈表 A 為 [4,1,8,4,5],鏈表 B 為 [5,0,1,8,4,5]。在 A 中,相交節點前有 2 個節點;在 B 中,相交節點前有 3 個節點。

示例 2:


輸入:intersectVal = 2, listA = [0,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1
輸出:Reference of the node with value = 2
輸入解釋:相交節點的值為 2 (注意,如果兩個列表相交則不能為 0)。從各自的表頭開始算起,鏈表 A 為 [0,9,1,2,4],鏈表 B 為 [3,2,4]。在 A 中,相交節點前有 3 個節點;在 B 中,相交節點前有 1 個節點。

示例 3:


輸入:intersectVal = 0, listA = [2,6,4], listB = [1,5], skipA = 3, skipB = 2
輸出:null
輸入解釋:從各自的表頭開始算起,鏈表 A 為 [2,6,4],鏈表 B 為 [1,5]。由于這兩個鏈表不相交,所以 intersectVal 必須為 0,而 skipA 和 skipB 可以是任意值。
解釋:這兩個鏈表不相交,因此返回 null。

注意:

如果兩個鏈表沒有交點,返回 null.
在返回結果后,兩個鏈表仍須保持原有的結構。
可假定整個鏈表結構中沒有循環。
程序盡量滿足 O(n) 時間復雜度,且僅用 O(1) 內存。

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/intersection-of-two-linked-lists
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。

思路:根據(a+b).length=(b+a).length
第一輪后若不相同,指針指向另一個鏈表的頭結點

/*** 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) {if(headA==NULL)return NULL;if(headB==NULL)return NULL;ListNode* pA=headA;ListNode* pB=headB;while(pA!=pB)//遍歷兩個鏈表{pA=pA==NULL?headB:pA->next; pB=pB==NULL?headA:pB->next;//同時為NULL則跳出循環,所以兩輪內必定結束}return pA;} };

思路來源于力扣大神SEU.FidGet

public class Solution {public ListNode getIntersectionNode(ListNode headA, ListNode headB) {/**定義兩個指針, 第一輪讓兩個到達末尾的節點指向另一個鏈表的頭部, 最后如果相遇則為交點(在第一輪移動中恰好抹除了長度差)兩個指針等于移動了相同的距離, 有交點就返回, 無交點就是各走了兩條指針的長度**/if(headA == null || headB == null) return null;ListNode pA = headA, pB = headB;// 在這里第一輪體現在pA和pB第一次到達尾部會移向另一鏈表的表頭, 而第二輪體現在如果pA或pB相交就返回交點, 不相交最后就是null==nullwhile(pA != pB) {pA = pA == null ? headB : pA.next;pB = pB == null ? headA : pB.next;}return pA;} }

總結

以上是生活随笔為你收集整理的相交链表解法一的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 狼干综合 | 精品一区二区三区免费视频 | 精品伦一区二区三区 | 99re这里只有精品在线 | 日皮视频免费看 | 嫩模一区 | 美女扒开尿口给男人捅 | 亚洲欧美不卡 | 91九色论坛 | 亚洲精品久久久久国产 | 精品免费国产一区二区三区四区 | 91大神在线观看视频 | 国产精品18p | 特级丰满少妇一级aaaa爱毛片 | 国产另类在线 | 免费成人在线观看 | 久久久久久久久久影院 | 欧美春色 | 狠狠爱av | 秋葵视频成人 | 天天色视频| 无遮挡的裸体按摩的视频 | 91一区二区在线观看 | 亚洲30p | 色综合狠狠 | 奇米超碰在线 | 嫩草影院懂你的影院 | 爱爱中文字幕 | 不卡中文字幕 | 中文精品在线观看 | 天堂网wwww| 黄色一区二区视频 | 精品国产成人av在线免 | 裸体喂奶一级裸片 | 韩国日本美国免费毛片 | 中文字幕精品一二三四五六七八 | 夜夜嗨aⅴ一区二区三区 | 丰满饥渴老女人hd | 国产一区不卡在线 | 黄色性视频| 女女h百合无遮涩涩漫画软件 | 级毛片| 久久午夜鲁丝片 | 91av在线视频观看 | 哪里看毛片 | 日韩精品电影在线观看 | 91av视频网| 久久久男人的天堂 | 日本天堂免费a | 91黄色在线视频 | 校花被c到呻吟求饶 | 少妇高潮大叫好爽喷水 | 亚洲国产成人精品91久久久 | 国产激情福利 | 亚洲一区视频在线 | 国产亚洲电影 | 狠狠天天 | 最新一区二区三区 | av中文字幕免费在线观看 | 日日嗨av一区二区三区四区 | 精品成人一区 | 黄色国产在线观看 | 又污又黄又爽的网站 | 一级黄色片视频 | 久久久国产亚洲 | 亚洲精选av | 尤物videos另类xxxx| 国模婷婷 | 亚洲性影院 | 好看的黄色录像 | 欧美黑人激情 | 亚洲综合精品视频 | 熟妇熟女乱妇乱女网站 | 9.1在线观看免费 | 婷婷的五月天 | 黄a在线 | 暧暧视频在线观看 | 淫人网| 大地资源影视在线播放观看高清视频 | 美女国产视频 | 性感少妇av| 影音先锋国产精品 | 久久久精品久久 | 亚欧美| 亚洲欧美日韩系列 | ⅹxxxxhd亚洲日本hd老师 | 日韩欧美国产一区二区三区 | 欧美在线视频免费观看 | 美女网站黄页 | 久草手机在线 | 韩国三级hd中文字幕的背景音乐 | 超碰国产97 | 狂野少女电影在线观看国语版免费 | 午夜综合 | 国产美女精品视频 | 久久久亚洲一区二区三区 | 日韩少妇一区 | www.久久久.com| 日日拍拍 |