面試題-鏈表(2)

1.合并兩個有序鏈表:

21. 合并兩個有序鏈表 - 力扣(LeetCode)

?

public ListNode mergeTwoLists(ListNode headA, ListNode headB){ListNode newhead=new ListNode(-1);ListNode cur=newhead;while(headA!=null&&headB!=null){if(headA.val<headB.val){cur.next=headA;headA=headA.next;cur=cur.next;}else{cur.next=headB;headB=headB.next;cur=cur.next;}}
if(headA==null){cur.next=headB;
}
if(headB==null){cur.next=headA;
}
return newhead.next;
}

?2.鏈表的分割:

鏈表分割_牛客題霸_牛客網 (nowcoder.com)

public ListNode partition(ListNode pHead, int x) {if(pHead==null){//如果鏈表為空,則提前返回return null;}ListNode bs=null;ListNode be=null;ListNode as=null;ListNode ae=null;ListNode cur=pHead;while(cur!=null){//開始遍歷鏈表if(cur.val<x){//第一種情況if(bs==null){//第一次插入bs=be=cur;}else{be.next=cur;be=be.next;}}else{//第二種情況if(as==null){//第一次插入as=ae=cur;}else{ae.next=cur;ae=ae.next;}}cur=cur.next;}if(bs==null){//如果沒有小于x的節點,直接返回大于等于x的節點return as;}if(as!=null){//如果大于x的節點不為空ae.next=null;}be.next=as;//綁定兩段鏈表return bs;}

?3.鏈表的回文結構:

鏈表的回文結構_牛客題霸_牛客網 (nowcoder.com)

public boolean chkPalindrome(ListNode A) {ListNode slow=A;ListNode fast=A;while(fast!=null&&fast.next!=null){//開始找中間節點slow=slow.next;fast=fast.next.next;}ListNode cur=slow.next;while(cur!=null){//開始反轉slow后面的鏈表ListNode curN=cur.next;cur.next=slow;slow=cur;cur=curN;}while(A!=slow){//一個從頭開始走,一個從尾開始走if(A.val!=slow.val){//一旦兩值不相同,返回falsereturn false;}if(A.next==slow){//前提在值相同的情況下,偶個節點的情況return true ;       }A=A.next;slow=slow.next;}return true ;//能走到這一步,返回真}

?4.相交鏈表:

160. 相交鏈表 - 力扣(LeetCode)

 public ListNode getIntersectionNode(ListNode headA, ListNode headB) {if(headA==null||headB==null){//兩個鏈表有一個為空,就返回nullreturn null;}ListNode pl=headA;ListNode ps=headB;int a=0,b=0;while(pl!=null){//分別求各鏈表的長度pl=pl.next;a++;}while(ps!=null){ps=ps.next;b++;}pl=headA;//重新指向頭結點ps=headB;if(a<b){//使pl一直指向長的鏈表,ps指向短的鏈表pl=headB;ps=headA;}int len=a>b?(a-b):(b-a);while(len!=0){//移動長鏈表到合適的位置pl=pl.next;len--;}while(pl!=null&&ps!=null){//同時遍歷兩個鏈表if(ps==pl){//相遇提前返回return ps;}ps=ps.next;pl=pl.next;}return null;}

?5.環形鏈表:

141. 環形鏈表 - 力扣(LeetCode)

public boolean hasCycle(ListNode head) {ListNode slow=head;ListNode fast=head;while(fast!=null&&fast.next!=null){//開始遍歷鏈表fast=fast.next.next;//快指針走兩步slow=slow.next;//慢指針走一步if(slow==fast){//如果相遇return true;}}return false;//不相遇}

6.環形鏈表2:

142. 環形鏈表 II - 力扣(LeetCode)

 public ListNode detectCycle(ListNode head) {if(head==null){//如果鏈表為空return null;}ListNode slow=head;ListNode fast=head;while(fast!=null&&fast.next!=null){//開始找相遇節點fast=fast.next.next;//快指針走兩步slow=slow.next;//慢指針走一步if(slow==fast){//如果相遇break;}}if(fast==null||fast.next==null){//判斷鏈表是否成環return null;}slow=head;//重置slow節點,此時fast節點指向相遇點while(slow!=fast){slow=slow.next;fast=fast.next;}return slow;}

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

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

相關文章

微軟Entra新安全功能引發大規模賬戶鎖定事件

誤報觸發大規模鎖定 多家機構的Windows管理員報告稱&#xff0c;微軟Entra ID新推出的"MACE"&#xff08;泄露憑證檢測應用&#xff09;功能在部署過程中產生大量誤報&#xff0c;導致用戶賬戶被大規模鎖定。這些警報和鎖定始于昨夜&#xff0c;部分管理員認為屬于誤…

【MATLAB第117期】#源碼分享 | 基于MATLAB的SSM狀態空間模型多元時間序列預測方法(多輸入單輸出)

【MATLAB第117期】#源碼分享 | 基于MATLAB的SSM狀態空間模型多元時間序列預測方法&#xff08;多輸入單輸出&#xff09; 引言 本文使用狀態空間模型實現失業率遞歸預測&#xff0c;狀態空間模型&#xff08;State Space Model, SSM&#xff09;是一種用于描述動態系統行為的…

谷歌瀏覽器搜索后的頁面總是覆蓋當前頁面

最近將搜索引擎換為谷歌后&#xff0c;發現&#xff0c;每次搜索完的結果頁面總是覆蓋當前頁面&#xff0c;非常不方便&#xff0c;在瀏覽器設置中又找不到類似設置的選項&#xff0c;然后終于在一個博主“如何設置使谷歌瀏覽器打開鏈接自動跳轉到新標簽頁而不是覆蓋當前頁面?…

記錄學習的第三十天

今天終于又開始寫博客了。 還是滑動窗口問題&#xff0c;這段時間不出意外都是這了 上面的思路是我自己做的&#xff0c;但是不知道為什么不行&#xff0c;有沒有大佬能指點一下我。 接下來這道題是進階的。不過我之前的基礎都做的很艱難&#xff0c;道阻且長啊。

QTextDocument 入門

一、QTextDocument QTextDocument 是 Qt 中用于處理富文本文檔的核心類&#xff0c;支持文本格式、圖片、表格等復雜內容。 1. QTextDocument 入門 1.1 基本概念 QTextDocument 是 Qt 中用于處理富文本內容的核心類&#xff0c;它提供了&#xff1a; 結構化文本存儲&#x…

WebRTC服務器Coturn服務器相關測試工具

1、概述 在安裝開源的webrtc服務器coturn服務器后&#xff0c;會附帶安裝coturn的相關工具&#xff0c;主要有以下幾種工具 2、turnadmin工具 說明&#xff1a;服務器命令行工具&#xff0c;提供添加用戶、添加管理員、生成TURN密鑰等功能&#xff0c;turnadmin -h查看詳細用…

如何創建Vue3工程

1.首先下載環境 &#xff08;默認下好了VS code&#xff09; Node.js: Node.js 中文網 — 下載 Node.js 選擇要下載的版本 檢查環境&#xff1a; 在命令行中輸入 node ,檢查版本號 2.創建工程 1.找到自己要創建工程的文件目錄&#xff0c;右鍵打開打開終端 在終端輸入創…

基于大模型的肛裂手術全流程預測與治療方案研究報告

目錄 一、引言 1.1 研究背景與意義 1.2 研究目標與創新點 1.3 研究方法與技術路線 二、肛裂概述與大模型技術原理 2.1 肛裂的醫學定義與分類 2.2 肛裂的發病機制與臨床癥狀 2.3 大模型技術簡介 三、大模型在肛裂術前預測的應用 3.1 術前風險因素分析與數據收集 3.2 …

【趣味小游戲】--掃雷游戲

目錄 一.test.c部分 二.game.h部分 三.game.c部分 前言:前面學習了數組和函數等c語言相關知識&#xff0c;這篇文章我們將通過這些知識分為三個文件來完成掃雷游戲&#xff1b; 1.test.c //文件中寫游戲的測試邏輯 2.game.c //文件中寫游戲中函數的實現等 3.game.h. //文件中寫…

【微服務】SpringBoot制作Docker鏡像接入SkyWalking詳解

目錄 一、前言 二、SkyWalking介紹 2.1 SkyWalking是什么 2.2 SkyWalking核心功能 2.3 SkyWalking整體架構 2.4 SkyWalking主要工作流程 三、前置準備 3.1 搭建SkyWalking服務 3.1.1 下載安裝包 3.1.2 上傳服務器目錄 2.1.3 數據庫持久化配置說明 3.1.4 啟動skywalk…

從零開始構建微博爬蟲與數據分析系統

從零開始構建微博爬蟲與數據分析系統 引言 社交媒體平臺蘊含著海量的信息和數據&#xff0c;通過對這些數據的收集和分析&#xff0c;我們可以挖掘出有價值的見解。本文將詳細介紹如何構建一個完整的微博爬蟲和數據分析系統&#xff0c;從數據爬取、清洗、到多維度分析與可視…

深入探索RAG:用LlamaIndex為大語言模型擴展知識,實現智能檢索增強生成

大型語言模型&#xff08;LLM&#xff09;&#xff0c;如ChatGPT和Llama&#xff0c;在回答問題方面表現出色&#xff0c;但它們的知識僅限于訓練時所獲取的信息。它們無法訪問私有數據&#xff0c;也無法在訓練截止日期之后學習新知識。那么&#xff0c;核心問題就是……我們如…

【延遲雙刪】簡單解析

使用場景&#xff1a;【高并發】情況下的做【更新操作】 什么是延遲雙刪 首次刪除&#xff1a;當需要更新某個數據項時&#xff0c;首先刪除緩存中的該項。 更新數據庫&#xff1a;接著&#xff0c;更新數據庫中的該項。 短暫延遲&#xff1a;然后等待一段很短的時間&#xff…

解決Windows安全中心顯示空白頁面

1、電腦重裝系統后&#xff0c;發現原本一些軟件打不開了&#xff0c;電腦莫名認為有病毒&#xff0c;自動刪除插件。附圖。 2、第一反應是電腦防火墻的原因&#xff0c;默認威脅防護識別到了病毒軟件&#xff0c;自動刪除。在開始屏幕搜Windows安全中心&#xff0c;打開之后發…

【回眸】error: failed to compile `xxxxxx`重裝rust環境

在ubuntu上安裝軟件報錯 error: failed to compile cxx2flow v0.6.2 Caused by: package cargo-platform v0.1.9 cannot be built because it requires rustc 1.78 or newer, while the currently active rustc version is 1.75.0 Try re-running cargo install with --lo…

算法—冒泡排序—js(教學示例、小數據)

冒泡排序原理 冒泡排序是一種簡單的排序算法&#xff0c;通過重復遍歷數組&#xff0c;比較相鄰元素并交換位置&#xff0c;使較大的元素逐漸“浮”到數組末尾。 特點 時間復雜度&#xff1a;平均 O(n)&#xff0c;最優&#xff08;已有序時&#xff09;O(n) 空間復雜度&#…

linux sysfs的使用

在Linux內核驅動開發中&#xff0c;device_create_file 和 device_remove_file 用于動態創建/刪除設備的 sysfs 屬性文件&#xff0c;常用于暴露設備信息或控制參數。以下是完整示例及詳細說明&#xff1a; 1. 頭文件引入 #include <linux/module.h> #include <linux/…

利用 Deepseek 和 Mermaid 畫流程圖

提示詞 你是一個產品經理&#xff0c;請繪制一個報名比賽的流程圖&#xff0c;要求生成符合Mermaid語法的代碼&#xff0c;具體要求如下&#xff1a; 1.注冊賬號 2.填寫報名信息 3.參加比賽 4.查看比賽結果 生成的結果 flowchart TDA([開始]) --> B[注冊賬號]B --> C{賬…

【圖像標注技巧】目標檢測圖像標注技巧

介紹一些圖像標注技巧。之前引用過別人的文章 yolo目標檢測 技巧 trick 提升模型性能&#xff0c;deep research檢測調研報告也可以進行參考。 拉框類的標注&#xff0c;如果你不確定哪種方法好&#xff0c;你可以把所標注區域的都剪切出來&#xff0c;然后站在屏幕一米之外瞇…

數字信號處理技術架構與功能演進

數字信號處理&#xff08;DSP&#xff09;是通過數字運算實現信號分析、變換、濾波及調制解調的技術領域&#xff0c;其發展過程與技術應用如下&#xff1a; 一、定義與核心功能 技術定義&#xff1a;通過算法將模擬信號轉換為數字形式進行處理&#xff0c;具有高精度、可編程…