【leetcode】第2章 鏈表

203.?移除鏈表元素

  • 方法:添加一個虛擬節點,這不用考慮頭節點刪除情況
public ListNode removeElements(ListNode head, int val) {// 虛擬節點,指向頭節點ListNode dummy = new ListNode(0);dummy.next = head;ListNode p = dummy;// 找到被刪除節點的前一個節點,進行刪除while (p.next != null) {// 若相等,則移除元素if (p.next.val == val) {p.next = p.next.next;}else {p = p.next;}}return dummy.next;
}

707.?設計鏈表

  • 帶有
class ListNode{int val;ListNode next;ListNode(){};ListNode(int val) {this.val = val;}
}class MyLinkedList {int size;ListNode dummy;// 初始化鏈表public MyLinkedList() {size = 0;dummy = new ListNode(0);}public int get(int index) {if (index < 0 || index >= size) {return -1;}ListNode cur = dummy;for (int i = index; i > 0; --i){cur = cur.next;}return cur.next.val;}public void addAtHead(int val) {ListNode node = new ListNode(val);node.next = dummy.next;dummy.next = node;size++;}public void addAtTail(int val) {// 找到最后一個元素ListNode cur = dummy;ListNode node = new ListNode(val);while (cur.next != null) {cur = cur.next;}cur.next = node;size++;}public void addAtIndex(int index, int val) {if (index > size) return;// 找到第index個節點之前ListNode cur = dummy;ListNode node = new ListNode(val);for (int i = index; i > 0; --i){cur = cur.next;}node.next = cur.next;cur.next = node;size++;}public void deleteAtIndex(int index) {if (index < 0 || index >= size) return;ListNode cur = dummy;if (index == 0) {dummy = dummy.next;}for (int i = index; i > 0; --i){cur = cur.next;}cur.next = cur.next.next;size--;}
}

反轉鏈表

  1. 雙指針法
public static ListNode reverseList(ListNode head) {// 輸入:head = [1,2,3,4,5]//輸出:[5,4,3,2,1]ListNode pre = null;ListNode cur = head;while (cur != null) {ListNode tmp = cur.next;// 反轉cur.next = pre;// 迭代當前指向pre = cur;cur = tmp;}return pre;
}
  1. 迭代法
public static ListNode reverseList(ListNode head) {// 輸入:head = [1,2,3,4,5]//輸出:[5,4,3,2,1]return reverse(null,head);
}public static ListNode reverse(ListNode pre,ListNode cur){if (cur == null) {return pre;}ListNode tmp = cur.next;cur.next = pre;return reverse(cur,tmp);
}

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

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

相關文章

數據結構:樹狀數組

老規矩&#xff0c;推薦一篇原理講解清晰的博客&#xff01;&#xff08;樹狀數組(詳細分析應用)&#xff0c;看不懂打死我!_樹形數組_鮮果維他命的博客-CSDN博客&#xff09; 相對于線段樹&#xff0c;樹狀數組的優點就是代碼簡潔&#xff0c;容易修改。單缺點就是優點問題只…

計算機視覺中的特征檢測和描述

一、說明 這篇文章是關于計算機視覺中特征檢測和描述概念的簡要理解。在其中&#xff0c;我們探討了它們的定義、常用技術、簡單的 python 實現和一些限制。 二、什么是特征檢測和描述&#xff1f; 特征檢測和描述是計算機視覺中的基本概念&#xff0c;在圖像識別、對象跟蹤和圖…

Beats:使用 Filebeat 將 golang 應用程序記錄到 Elasticsearch - 8.x

毫無疑問&#xff0c;日志記錄是任何應用程序最重要的方面之一。 當事情出錯時&#xff08;而且確實會出錯&#xff09;&#xff0c;我們需要知道發生了什么。 為了實現這一目標&#xff0c;我們可以設置 Filebeat 從我們的 golang 應用程序收集日志&#xff0c;然后將它們發送…

Maven教程_編程入門自學教程_菜鳥教程-免費教程分享

教程簡介 Maven 是一款基于 Java 平臺的項目管理和整合工具&#xff0c;它將項目的開發和管理過程抽象成一個項目對象模型&#xff08;POM&#xff09;。開發人員只需要做一些簡單的配置&#xff0c;Maven 就可以自動完成項目的編譯、測試、打包、發布以及部署等工作。Maven 是…

微信小程序備案流程

微信小程序備案流程 &#x1f4d4; 千尋簡筆記介紹 千尋簡筆記已開源&#xff0c;Gitee與GitHub搜索chihiro-notes&#xff0c;包含筆記源文件.md&#xff0c;以及PDF版本方便閱讀&#xff0c;且是用了精美主題&#xff0c;閱讀體驗更佳&#xff0c;如果文章對你有幫助請幫我…

二、異常日志

二、異常日志 &#xff08;一&#xff09;、錯誤碼 錯誤碼的制定原則&#xff1a;快速溯源、溝通標準化錯誤碼不體現版本號和錯誤等級信息全部正常&#xff0c;但不得不填充錯誤碼時返回五個零&#xff1a;00000錯誤碼為字符串類型&#xff0c;共 5 位&#xff0c;分成兩個部分…

win10 anaconda pytorch avalanche-lib 實驗步驟記錄

conda create --name test_python3.10 conda activate test_python3.10 配置conda國內源(北外) conda install pytorch torchvision torchaudio cpuonly -c pytorch pip3 install avalanche-lib -i https://pypi.tuna.tsinghua.edu.cn/simple conda install jupyter jupyte…

[tidb] tiup升級tidb的版本到 v7.1.1

備份 為了避免數據丟失&#xff0c;升級前需要備份當前tidb集群的數據&#xff0c;參考 TiDB 備份與恢復概述 | PingCAP 文檔中心 說明 由于新版本的tidb的tiflash需要cpui支持avx2&#xff0c;所有升級前先驗證當前升級的服務器是否支持avx2。升級的文檔可以參考 使用 TiUP…

Android布局【TableLayout】

文章目錄 說明常見屬性子控件設置屬性 項目結構主要代碼 說明 TableLayout也稱為表格布局 常見屬性 android:collapseColumns&#xff1a;設置需要被隱藏的列的序列號&#xff0c;從0開始android:stretchColumns&#xff1a;設置允許被拉伸的列的列序號&#xff0c;從0開始&…

docker私有鏡像倉庫搭建

1、下載registry鏡像 docker pull registry:2.52、生成登錄私有倉庫的用戶名以及密碼 mkdir -p /opt/registry/auth/ docker run --entrypoint htpasswd registry:2.5 -Bbn username userpwd >> /opt/registry/auth/htpasswd3、創建配置文件 mkdir -p /opt/registry/…

Git - 配置代理 和 取消代理配置

一. 配置代理 (使git走網路代理) git config --global http.proxy socks5://127.0.0.1:1080 git config --global https.proxy socks5://127.0.0.1:1080 其中 1080 是 SOCKS 代理的端口&#xff0c;一般默認 1080&#xff0c;可以在代理工具的設置中查看 地址記錄&#xff1a…

Python中使用隧道爬蟲ip提升數據爬取效率

作為專業爬蟲程序員&#xff0c;我們經常面臨需要爬取大量數據的任務。然而&#xff0c;有些網站可能會對頻繁的請求進行限制&#xff0c;這就需要我們使用隧道爬蟲ip來繞過這些限制&#xff0c;提高數據爬取效率。本文將分享如何在Python中使用隧道爬蟲ip實現API請求與響應的技…

(十八)大數據實戰——Hive的metastore元數據服務安裝

前言 Hive的metastore服務作用是為Hive CLI或者Hiveserver2提供元數據訪問接口。Hive的metastore 是Hive元數據的存儲和管理組件&#xff0c;它負責管理 Hive 表、分區、列等元數據信息。元數據是描述數據的數據&#xff0c;它包含了關于表結構、存儲位置、數據類型等信息。本…

Android Jetpack Compose 中的分頁與緩存展示

Android Jetpack Compose 中的分頁與緩存展示 在幾乎任何類型的移動項目中&#xff0c;移動開發人員在某個時候都會處理分頁數據。如果數據列表太大&#xff0c;無法一次從服務器檢索完畢&#xff0c;這就是必需的。因此&#xff0c;我們的后端同事為我們提供了一個端點&#…

ArcGIS Pro應用—暨基礎入門、制圖、空間分析、影像分析、三維建模、空間統計分析與建模、python融合、案例應用全流程科研能力提升教程

詳情點擊鏈接&#xff1a;ArcGIS Pro應用—暨基礎入門、制圖、空間分析、影像分析、三維建模、空間統計分析與建模、python融合、案例應用全流程科研能力提升教程 第一&#xff1a;GIS及ArcGIS Pro 1.GIS基本原理及常用軟件 2.ArcGIS Pro 安裝與配置 3.ArcGIS Pro 3.0 的新…

C語言自動抓取淘寶商品詳情網頁數據,實現輕松高效爬蟲

你是否曾經遇到過需要大量獲取網頁上的數據&#xff0c;但手動復制粘貼又太過費時費力&#xff1f;那么這篇文章就是為你而寫。今天我們將會詳細討論如何使用C語言實現自動抓取網頁上的數據。本文將會從以下8個方面進行逐步分析討論。 1. HTTP協議的基本原理 在開始之前&…

小白到運維工程師自學之路 第七十三集 (kubernetes應用部署)

一、安裝部署 1、以Deployment YAML方式創建Nginx服務 這個yaml文件在網上可以下載 cat nginx-deployment.yaml apiVersion: apps/v1 #apiVersion是當前配置格式的版本 kind: Deployment #kind是要創建的資源類型&#xff0c;這里是Deploymnet metadata: #metadata是該資源…

Photoshop多圖片與多窗口下排列操作方法

首先&#xff0c;在Photoshop中打開6張圖片&#xff0c;在“窗口”菜單下切換窗口排列狀態&#xff1a; 在 “窗口”菜單下對窗口進行排列&#xff0c;分別呈現如下&#xff1a; &#xff08;一&#xff09;. 點擊“窗口” -> “排列”->"全部垂直拼貼": &am…

本地oracle登錄賬號鎖定處理,the account is locked

1.打開cmd命令窗口 2.打開sqlplus: sqlplus /nolog(加/nolog是不登錄服務器的意思&#xff0c;不加就需要輸賬號密碼) 3.切換到管理員&#xff1a;conn / as sysdba; 第2步第3步可以合并&#xff0c;直接使用sysdba登錄&#xff1a;sqlplus / as sysdba; 4.解鎖賬號&#x…

大端和小端

大端和小端 大端&#xff08;Big Endian&#xff09;和小端&#xff08;Little Endian&#xff09;是兩種不同的字節序排列方式&#xff0c;用于解釋多字節數據在內存中的存儲順序。 在大端字節序中&#xff0c;高位字節&#xff08;最高有效位&#xff09;存儲在低位地址&am…