代碼隨想錄算法訓練營第3天(鏈表1)| 203.移除鏈表元素 707.設計鏈表 206.反轉鏈表

一、203.移除鏈表元素

題目:203. 移除鏈表元素 - 力扣(LeetCode)

視頻:手把手帶你學會操作鏈表 | LeetCode:203.移除鏈表元素_嗶哩嗶哩_bilibili

講解:代碼隨想錄

注意:

針對頭結點和非頭結點的刪除方式是不一樣的:

正常節點:要找到該節點的上一節點

頭結點:直接把 head 往后移一位

所以就要進行判斷,要刪除的節點是不是頭結點(方法一)

或者,在頭結點前設立一個虛擬節點(dummy head)(方法二)

方法一:判斷鏈表刪除元素

class Solution {public ListNode removeElements(ListNode head, int val) {while (head != null && head.val == val) {head = head.next;}ListNode curr = head;while (curr != null && curr.next != null) { if (curr.next.val == val) {curr.next = curr.next.next;} else {curr = curr.next;}}return head;}
}

要點 1:

判斷頭結點是否符合的時候,使用 if 就只能判斷一次,如果第二個元素也符合條件,就漏刪了

所以要用 while ,在頭結點不符合條件的時候,才繼續往下走

要點 2:

往后查找的時候,要定義一個指針,那么指針的位置指向哪里?

如果是第二位,第二位符合刪除條件,找不到上一位的 next 指針。(x)

所以要指向頭結點

嘗試過程:

class Solution {public ListNode removeElements(ListNode head, int val) {while (head != null && head.val == val) {head = head.next;}ListNode curr = head;while (curr.next != null && curr != null) {     //這里有問題!!if (curr.next.val == val) {curr.next = curr.next.next;} else {curr = curr.next;}}return head;}
}

報這個錯誤的原因:

雖然從邏輯上看是想同時確保當前節點 curr 和它的下一個節點 curr.next 都不為 null,但如果 curr 本身已經是 null 了,再去訪問 curr.next 就會直接拋出空指針異常。

正確的做法應該是先判斷 curr 是否為 null再去判斷 curr.next 是否為 null,像這樣修改條件為 while (curr!= null && curr.next!= null)

方法二:設置虛擬頭結點

class Solution {public ListNode removeElements(ListNode head, int val) {ListNode dummy = new ListNode();dummy.next = head;ListNode curr = dummy;while(curr != null && curr.next != null){if(curr.next.val == val){curr.next = curr.next.next;} else {curr = curr.next;}}return dummy.next;}
}

注意頭結點的指針是不能更改的,因為最后要用到頭結點返回。

二、707.設計鏈表

題目:707. 設計鏈表 - 力扣(LeetCode)

視頻:幫你把鏈表操作學個通透!LeetCode:707.設計鏈表_嗶哩嗶哩_bilibili

講解:代碼隨想錄

利用虛擬頭結點方式,對所有結點統一操作。

class MyLinkedList {class ListNode {int val;ListNode next;ListNode(int val) {this.val = val;}}private int size;private ListNode head;// 初始化public MyLinkedList() {this.size = 0;this.head = new ListNode(0);}public int get(int index) {if (index < 0 || index >= size) {return -1;}ListNode cur = head;for (int i = 0; i <= index; i++) {cur = cur.next;}return cur.val;}public void addAtHead(int val) {ListNode newNode = new ListNode(val);newNode.next = head.next;head.next = newNode;size++;}public void addAtTail(int val) {ListNode newNode = new ListNode(val);ListNode cur = head;while (cur.next != null) {cur = cur.next;}cur.next = newNode;size++;}public void addAtIndex(int index, int val) {if (index < 0 || index >= size) {return;}ListNode cur = head;for (int i = 0; i < index; i++) {cur = cur.next;}ListNode newNode = new ListNode(val);newNode.next = cur.next;cur.next = newNode;size++;}public void deleteAtIndex(int index) {if(index < 0 || index >=size){return;}ListNode cur = head;for(int i=0; i<index; i++){cur = cur.next;}cur.next = cur.next.next;size--;}
}

三、206.反轉鏈表

題目:

視頻:

講解:


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

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

相關文章

NetMQ里Push-Pull模式,消息隔一收一問題小記

問題&#xff1a; 本機環境下&#xff0c;在push端向pull端發送消息的過程中&#xff0c;發現同一個進程里的pusher和puller代碼&#xff0c;可以準確地完成收發&#xff1b; 然而&#xff0c;將代碼放在兩個進程里&#xff0c;將pusher發送的消息從1計數&#xff0c;puller端竟…

CES Asia 2025科技盛宴,AI智能體成焦點

2025第七屆亞洲消費電子技術展&#xff08;CES Asia賽逸展&#xff09;將在北京拉開帷幕&#xff0c;AI智能體有望成為展會的核心亮點。 深圳市人工智能行業協會發文表示全力支持CES Asia 2025&#xff08;賽逸展&#xff09;&#xff0c;稱其為人工智能領域的創新發展提供了強…

matlab編寫分段Hermite插值多項式

文章目錄 原理使用分段Hermite插值多項式原因公式第一類的兩個插值積函數第二類的兩個插值積函數 例題法一法二 代碼分段 Hermite 插值的思路&#xff1a;分段 Hermite 插值多項式的構造&#xff1a;MATLAB 實現代碼&#xff1a;結果如圖&#xff1a;注歸一化變量的作用&#x…

Cline(原Claude Dev)開源的IDE AI插件,如何搭配OpenRouter實現cursor功能,Cline怎么使用

Cline&#xff08;原Claude Dev&#xff09;是一個開源的IDE AI插件&#xff0c;可以使用你的命令行界面和編輯器的人工智能助手。 你可以直接在VS Code編輯器進行安裝。如果你使用過Cursor AI IDE的話&#xff0c;可以嘗試最新發布的Cline3.1版本。 在OpenRouter上&#xff0…

計科高可用服務器架構實訓(防火墻、雙機熱備,VRRP、MSTP、DHCP、OSPF)

一、項目介紹 需求分析&#xff1a; &#xff08;1&#xff09;總部和分部要求網絡拓撲簡單&#xff0c;方便維護&#xff0c;網絡有擴展和冗余性&#xff1b; &#xff08;2&#xff09;總部分財務部&#xff0c;人事部&#xff0c;工程部&#xff0c;技術部&#xff0c;提供…

企業級PHP異步RabbitMQ協程版客戶端 2.0 正式發布

概述 workerman/rabbitmq 是一個異步RabbitMQ客戶端&#xff0c;使用AMQP協議。 RabbitMQ是一個基于AMQP&#xff08;高級消息隊列協議&#xff09;實現的開源消息組件&#xff0c;它主要用于在分布式系統中存儲和轉發消息。RabbitMQ由高性能、高可用以及高擴展性出名的Erlan…

AsyncOperation.allowSceneActivation導致異步加載卡死

先看這段代碼&#xff0c;有個詭異的問題&#xff0c;不確定是不是bug public class Test : MonoBehaviour {void Start(){StartCoroutine(LoadScene(Ego.LoadingLevel));}IEnumerator LoadScene(string sceneName){LoadingUI.UpdateProgress(0.9f);yield return new WaitForS…

C#使用MVC框架創建WebApi服務接口

第一步,使用VS2019新建MVC-Web API應用程序 創建BridgeApi 第二步,運行將生成默認的示例網頁,網頁Url為 https://localhost:44361/home/index 右鍵 項目 添加 WebAPI控制器類 添加 我們可以看到App_Start目錄下 有三個文件: BundleConfig.cs代表 捆綁文件的引用 有腳本文件…

wordpress 房產網站篩選功能

自定義分類法創建 add_action( init, ashu_post_type ); function ashu_post_type() {register_taxonomy(province,post,array(label => 省,rewrite => array( slug => province ),hierarchical => true));register_taxonomy(city,post,array(label => 市,rewr…

hive遷移后修復分區慢,怎么辦?

我有1個30TB的分區表&#xff0c;客戶給的帶寬只有600MB&#xff0c;按照150%的耗時來算&#xff0c;大概要遷移17小時。 使用hive自帶的修復分區命令&#xff08;一般修復分區比遷移時間長一點&#xff09;&#xff0c;可能要花24小時。于是打算用前面黃大佬的牛B方案。 Hive增…

慧集通(DataLinkX)iPaaS集成平臺-業務建模之業務對象(一)

通過左側導航菜單〖業務建模〗→〖業務對象〗&#xff0c;進入該界面&#xff1b;在該界面可以查看到系統中已存在的業務對象&#xff1b; 1.新建業務對象 在DatalinkX中進入【業務建模】的【業務對象】頁面&#xff0c;點擊【新建】按鈕進入新建頁面&#xff1b; 新建頁面左側…

Linux系統之hostname相關命令基本使用

Linux系統之hostname相關命令基本使用 一、檢查本地系統版本二、hostname命令的幫助說明中文幫助說明 三、hostname命令的基本使用1. 查看計算機名2. 查看本機上所有IP地址3. 查看主機FQDN4. 查看短主機名 四、hostnamectl命令的使用1. 查看主機詳細信息2. 設置主機名3. hostna…

DC系列靶場滲透--DC-3

目錄 環境搭建 開始滲透 掃存活 掃端口 掃服務 查看80端口 嘗試在80端口中的登陸頁面尋找sql注入失敗 掃目錄 進入/htaccess.txt目錄看一下 我們嘗試找一下Joomla3.7.0版本的漏洞 我們嘗試利用該漏洞 查數據庫名 查表名 查列名 查數據 找到密碼的可能的編碼方式…

js代理模式

允許在不改變原始對象的情況下&#xff0c;通過代理對象來訪問原始對象。代理對象可以在訪問原始對象之前或之后&#xff0c;添加一些額外的邏輯或功能。 科學上網過程 一般情況下,在訪問國外的網站,會顯示無法訪問 因為在dns解析過程,這些ip被禁止解析,所以顯示無法訪問 引…

uniapp 之 uni-forms校驗提示【提交的字段[‘xxx‘]在數據庫中并不存在】解決方案

目錄 場景問題代碼結果問題剖析解決方案 場景 uni-forms官方組件地址 使用uniapp官方提供的組件&#xff0c;某個表單需求&#xff0c;單位性質字段如果是高校&#xff0c;那么工作單位則是高校的下拉選擇格式&#xff0c;單位性質如果是其他的類型&#xff0c;工作單位則是手動…

深度學習知識點:RNN

文章目錄 1.簡單介紹2.網絡結構3.應對梯度消失 1.簡單介紹 循環神經網絡&#xff08;RNN&#xff0c;Recurrent Neural Network&#xff09;是一類用于處理序列數據的神經網絡。與傳統網絡相比&#xff0c;變化不是特別大&#xff0c;不如CNN的變化那么大。 為什么要有循環神經…

(leetcode算法題)287. 尋找重復數(經典題目,二分解法)

如果一個題目限定了數據范圍是[1, n]內的整數&#xff0c;那么這個題目可以思考的就是 nums[i]和 i 的關系&#xff0c;769. 最多能完成排序的塊 這個題就使用到了子數組中最大值和 連續[0, n - 1]的關系 而對于本題來說&#xff0c;也可以思考[1, n] 和 nums[i] 的關系&…

獲得PostgreSQL中級認證后,可以從事哪些工作崗位?

獲得 PostgreSQL 中級認證后&#xff0c;可以獲得的崗位 數據庫管理類 數據庫管理員&#xff08;DBA&#xff09;&#xff1a;負責 PostgreSQL 數據庫的日常維護、監控、備份與恢復、性能優化、安全管理等工作。確保數據庫的穩定運行和數據的安全性、完整性&#xff0c;及時處理…

4.1、二纖單向、二纖雙向、四纖雙向,網絡級保護

1、線性復用段保護&#xff08;LMSP&#xff09; 就像是給網絡業務傳輸準備的一個 “保險”。在 SDH 和 MSTP 網絡里&#xff0c;業務信號要通過一段一段的路&#xff08;復用段&#xff09;來傳輸&#xff0c;LMSP 就是為了保證這些路出問題的時候&#xff0c;業務還能正常走。…

【spark源碼修改】hive3.1.3 spark3.5.4編譯,需要修改源碼,最終編譯成功

【spark源碼修改】hive3.1.3 spark3.5.4編譯,需要修改源碼,最終編譯成功 1. 準備安裝包與maven編譯環境1.1 安裝環境準備1.2 修改pom1.3 打包命令2. 編譯與問題解決2.1 開始編譯 失敗, 缺包pentaho-aggdesigner-algorithm:pom:5.1.5-jhyde2.2 Hive Spark Remote Client 模塊…