2025年- H1-Lc109-160. 相交列表--java版

1.題目描述

在這里插入圖片描述

2.思路

“雙指針切換鏈表頭”
思路一:雙指針+路徑對齊
while (pA != pB) {
pA = (pA == null) ? headB : pA.next;
pB = (pB == null) ? headA : pB.next;
}

讓兩個指針走相同的總路徑長度!
設:

鏈表 A 獨有部分長度是 lenA

鏈表 B 獨有部分長度是 lenB

公共部分長度是 lenCommon

那兩個指針會走的路徑:

指針 A:先走 lenA + lenCommon,然后換到 B 頭再走 lenB

指針 B:先走 lenB + lenCommon,然后換到 A 頭再走 lenA

于是總長度都是:lenA + lenB + lenCommon
在這里插入圖片描述
在這里插入圖片描述

3.代碼實現

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode(int x) {*         val = x;*         next = null;*     }* }*/
public class Solution {public ListNode getIntersectionNode(ListNode headA, ListNode headB) {if(headA==null||headB==null) return null;ListNode PA=headA;ListNode PB=headB;while(PA!=PB){if(PA!=null){PA=PA.next;}else{PA=headB;}if(PB!=null){PB=PB.next;//如果PB列表有元素就直接指向下一個}else{PB=headA;//如果PB已經到末尾了,開始遍歷A列表}}return PB;//這邊返回PA和PB都可以}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/77010.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/77010.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/77010.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PyTorch 深度學習 || 6. Transformer | Ch6.3 Transformer 簡單案例

1. 簡單案例 這個代碼是一個簡單的 Transformer 模型的實現,這個例子展示了一個基本的序列到序列(seq2seq)任務,比如將一個數字序列轉換為另一個數字序列。可以用于學習和理解 Transformer 的基本結構和工作原理。 import torch import torch.nn as nn import math# 位置…

基礎算法篇(4)(藍橋杯常考點)—數據結構(進階)

前言 這期將會講到基礎算法篇里面的數據結構(進階),主要包括單調棧,單調隊列,并查集,擴展域并查集,帶權并查集,字符串哈希,Trie樹。 數據結構(進階)正文 單…

【AI學習】初步了解Gradio

Gradio 是一個開源的 Python 庫,專注于快速構建交互式 Web 界面,特別適用于機器學習模型、數據科學項目或任意 Python 函數的演示與部署。它通過極簡的代碼實現前后端一體化,無需前端開發經驗即可創建功能豐富的應用。以下是 Gradio 的核心特…

Overleaf 論文提交 Arxiv

Contents References 清除 Overleaf 中所有編譯 error,并且保證 main.tex 文件在 project 最上層參考文件 .bib 轉 .bbl. project 編譯成功后可以在 Overleaf 的 Recompile 按鈕右側找到 “Logs and output files”,點進去之后右下角可以點開 “Other lo…

【Android Audio】Parameter Framework - pfw

Parameter Framework - Android AudioPolicy Engine 使用 libengineconfigurable.so 來取締默認安卓音頻引擎 libenginedefault.so,因為默認安卓音頻引擎是通過代碼來決定策略,然而 libengineconfigurable 采用讀取pfw類型的文件來實現音頻策略配置。 …

服務器虛擬化技術深度解析:醫藥流通行業IT架構優化指南

一、服務器虛擬化的定義與原理 (一)技術定義:從物理到虛擬的資源重構 服務器虛擬化是通過軟件層(Hypervisor)將物理服務器的CPU、內存、存儲、網絡等硬件資源抽象為邏輯資源池,分割成多個相互隔離的虛擬機…

babel-runtime 如何縮小打包體積

🤖 作者簡介:水煮白菜王,一位前端勸退師 👻 👀 文章專欄: 前端專欄 ,記錄一下平時在博客寫作中,總結出的一些開發技巧和知識歸納總結?。 感謝支持💕💕&#…

劍指Offer(數據結構與算法面試題精講)C++版——day7

劍指Offer(數據結構與算法面試題精講)C版——day7 題目一:最多刪除一個字符得到回文題目二:回文子字符串的個數題目三:刪除倒數第k個節點 題目一:最多刪除一個字符得到回文 這里我們可以在經典的字符串回文…

2025年常見滲透測試面試題(題目+回答)

網絡安全領域各種資源,學習文檔,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各種好玩的項目及好用的工具,歡迎關注。 目錄 常見面試題 一、滲透測試經歷與技術復盤 二、高頻漏洞類型與攻防體系 三、滲透工具鏈與技術特性 四、…

大數據與人工智能之大數據架構(Hadoop、Spark、Flink)

一、核心特性與架構設計 1. Hadoop:分布式批處理的基石 核心組件: HDFS:分布式文件系統,支持大規模數據存儲。MapReduce:基于“分而治之”的批處理模型,適合離線分析。 架構特點: 批處理主導&…

從IoT到AIoT:智能邊界的拓展與AI未來趨勢預測

文章目錄 引言:從連接萬物到感知萬物1. AIoT的本質:將智能嵌入萬物2. AIoT的推動力量與挑戰2.1 推動力量2.2 關鍵挑戰 3. 五大AIoT未來趨勢預測趨勢一:邊緣智能將成為主流架構趨勢二:AI模型將向自適應與多任務演進趨勢三&#xff…

從本地新建文件夾到拉取遠程倉庫 dev 分支的完整步驟

《從本地新建文件夾到拉取遠程倉庫 dev 分支的完整步驟》 下面為你詳細介紹從本地新建文件夾開始,將遠程倉庫的 dev 分支拉取到本地的具體步驟: 1. 創建新文件夾 在本地電腦上新建一個文件夾,作為存放項目代碼的目錄。你可以通過圖形界面操…

python/pytorch雜聊

Dataset 是否需要自己定義:如果你使用的數據集不是 PyTorch 提供的標準數據集(如 MNIST、CIFAR-10 等),那么你需要繼承 torch.utils.data.Dataset 類并實現兩個方法:__len__() 和 __getitem__()。__len__() 應該返回數…

PHP 安全 E-mail

PHP 安全 E-mail 引言 隨著互聯網的普及和電子商務的發展,電子郵件成為了人們日常生活中不可或缺的通信工具。PHP作為一種廣泛使用的服務器端腳本語言,也經常被用于發送和接收電子郵件。然而,在PHP中處理電子郵件時,安全性問題不容忽視。本文將深入探討PHP安全發送電子郵…

【夜話系列】DelayQueue延遲隊列(下):實戰應用與面試精講

?? 本文是DelayQueue系列的下篇,聚焦實戰應用場景和性能優化。通過多個真實案例,帶你掌握DelayQueue在項目中的最佳實踐和性能調優技巧。 ?? 系列專欄推薦: JAVA集合專欄 【夜話集】JVM知識專欄數據庫sql理論與實戰小游戲開發文章目錄 一、DelayQueue實戰應用1.1 訂單超…

Redis(筆記)

簡介: 常用數據類型: 常用操作命令: Redis的Java客戶端: 操作字符串類型的數據: 操作Hash類型的數據: 操作列表類型的數據: 操作集合類型的數據: 操作有序集合類型數據: 通用命令…

PhotoShop學習05

1.選區基礎知識 選區,就是選定一些區域,我們對圖片的更改只在選區內生效,這樣可以精細調整圖片的部分而不會影響整體。它的快捷鍵是M。 我們用點擊鼠標后滑動就會出現虛線框,虛線框內的就是我們選定的區域。這時我們再滑動就會創…

使用Redission實現分布式鎖

分布式鎖在分布式系統中非常重要,主要用于解決多個進程/服務并發訪問共享資源時的數據一致性問題。在日常開發中常用于: 1. 防止重復操作(冪等性控制) 場景:用戶重復提交訂單、重復支付、重復點擊等。 示例&#xff1…

VScode 畫時序圖(FPGA)

1、先安裝插件: 2、然后就可以編寫一個.js文件,如下: {signal: [{name: clk, wave: p.......|..},{name: rstn, wave: 01......|..},{name: din_vld, wave: 0.1.0...|..},{name: din, wave: "x.x...|..", data: ["D0", …

嵌入式學習筆記——I2C

IIC協議詳解 一、IIC協議簡介二、IIC總線結構圖三、IIC通信流程詳解1. 空閑狀態 : 雙高空閑2. 起始信號(START): 時高數下開始3. 停止信號(STOP): 時高數上結束4. 數據傳輸格式 : 時高數穩,時低數變5. 應答信號 四、寫…