成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

動(dòng)圖:刪除鏈表的倒數(shù)第 N 個(gè)結(jié)點(diǎn)

開(kāi)發(fā) 前端
本文主要介紹一道面試中常考鏈表刪除相關(guān)的題目,即 leetcode 19. 刪除鏈表的倒數(shù)第 N 個(gè)結(jié)點(diǎn)。采用 雙指針 + 動(dòng)圖 的方式進(jìn)行剖析,供大家參考,希望對(duì)大家有所幫助。

 [[393057]]

本文轉(zhuǎn)載自微信公眾號(hào)「程序員小熊」,作者Dine。轉(zhuǎn)載本文請(qǐng)聯(lián)系程序員小熊公眾號(hào)。   

本文主要介紹一道面試中常考鏈表刪除相關(guān)的題目,即 leetcode 19. 刪除鏈表的倒數(shù)第 N 個(gè)結(jié)點(diǎn)。采用 雙指針 + 動(dòng)圖 的方式進(jìn)行剖析,供大家參考,希望對(duì)大家有所幫助。

刪除鏈表的倒數(shù)第 N 個(gè)結(jié)點(diǎn)

給你一個(gè)鏈表,刪除鏈表的倒數(shù)第 n 個(gè)結(jié)點(diǎn),并且返回鏈表的頭結(jié)點(diǎn)。

進(jìn)階:你能嘗試使用一趟掃描實(shí)現(xiàn)嗎?

解題思路

在鏈表中要?jiǎng)h除某個(gè)節(jié)點(diǎn) nodeB,必須先找到 nodeB 的前一節(jié)點(diǎn) nodeA ,再將 nodeA 指向 nodeB 的下一節(jié)點(diǎn) nodeC ,從而實(shí)現(xiàn)節(jié)點(diǎn) nodeB 的刪除。

例如要?jiǎng)h除鏈表 L(1->2->3->4->5) 中 值為 3 的節(jié)點(diǎn),首先得找到該節(jié)點(diǎn)的前一節(jié)點(diǎn)(值為 2 的節(jié)點(diǎn)),才能實(shí)現(xiàn)該節(jié)點(diǎn)的刪除,如下圖示:

題目要求刪除 倒數(shù)第 n 個(gè) 節(jié)點(diǎn),所以首先得找到 該節(jié)點(diǎn)的前一節(jié)點(diǎn) ,但由于不知道 整個(gè)鏈表的長(zhǎng)度,因此不知道 待刪除的節(jié)點(diǎn)是正數(shù)的第幾個(gè)節(jié)點(diǎn),所以很難從頭節(jié)點(diǎn)開(kāi)始遍歷時(shí)刪除掉這個(gè)節(jié)點(diǎn)。

思路一

先遍歷一遍鏈表,獲取整個(gè)鏈表的長(zhǎng)度;假設(shè)整個(gè)鏈表的長(zhǎng)度為 l,則可知要?jiǎng)h除的節(jié)點(diǎn)為第 l - n + 1 個(gè)節(jié)點(diǎn);再遍歷一遍,刪除倒數(shù)第 n 個(gè)節(jié)點(diǎn)。例如鏈表 L 為 1->2->3->4->5,n = 3,則要?jiǎng)h除的節(jié)點(diǎn)為 第 5 - 3 + 1 = 3 個(gè)節(jié)點(diǎn) 。

思路二

盡管思路一可行,但是需要 遍歷鏈表兩遍,不夠簡(jiǎn)潔,而且題目的 進(jìn)階 中也提到嘗試使用一趟掃描實(shí)現(xiàn),因此本文采用 雙指針 的策略,實(shí)現(xiàn)通過(guò)一次掃描刪除 倒數(shù)第 n 個(gè)節(jié)點(diǎn) 。

在上一期鏈表相關(guān)專題 虛擬頭節(jié)點(diǎn)秒殺鏈表問(wèn)題 中提到 增加虛擬頭節(jié)點(diǎn) 的策略解決鏈表問(wèn)題,增加虛擬頭節(jié)點(diǎn)的 好處 在于:不需要單獨(dú)考慮頭節(jié)點(diǎn),這樣對(duì)頭節(jié)點(diǎn)的處理就像跟其它節(jié)點(diǎn)一樣。本文也同樣采用這種策略。

舉栗

以鏈表 1->2->3->4->5,n = 3 為栗,如下如示。

按照上面分析,先要找到 倒數(shù)第 3 個(gè)節(jié)點(diǎn)的前一節(jié)點(diǎn),即值為 2 的節(jié)點(diǎn);

增加虛擬頭節(jié)點(diǎn)

值為 2 的節(jié)點(diǎn)是 倒數(shù)第 4 個(gè)節(jié)點(diǎn)(后往前數(shù)),增加兩指針 fast/slow,分別指向最后一個(gè)元素(NULL)和上圖中 target 的位置;

此時(shí) fast 跟 slow 之間的間距是固定(n = 3)的,找到 target(slow)后,只需要?jiǎng)h除其下一節(jié)點(diǎn)即可,但 slow 指向的節(jié)點(diǎn)前面有多少個(gè)節(jié)點(diǎn)該如何確定呢?

由于當(dāng)前已知 fast 和 slow 指向節(jié)點(diǎn)之間的長(zhǎng)度是固定的,只需要將這兩個(gè)指針向前挪,直到 slow 挪到虛擬頭節(jié)點(diǎn)(值為 0)的位置,此時(shí) fast 指向值為 4 的節(jié)點(diǎn)的位置,fast 只需要由虛擬頭節(jié)點(diǎn)的位置 右移 n + 1 = 4 即可。如下圖示:

當(dāng) fast 右移至值為 4 的節(jié)點(diǎn)時(shí),指針 slow 和 fast 同時(shí)右移,直至 fast 移到 NULL,此時(shí) slow 剛好到 target 位置,即指向 倒數(shù)第 n + 1 個(gè)節(jié)點(diǎn),如下圖示。

Show me the Code

c++

  1. ListNode* removeNthFromEnd(ListNode* head, int n) { 
  2.     ListNode* dummyHead = new ListNode(0); 
  3.     dummyHead->next = head; 
  4.     ListNode *slow = dummyHead, *fast = dummyHead; 
  5.     for (int i = 0; i < n + 1; ++i) { 
  6.         fast = fast->next
  7.     } 
  8.  
  9.     while (fast != NULL) { 
  10.         slow = slow->next
  11.         fast = fast->next
  12.     } 
  13.  
  14.     ListNode* delNode = slow->next
  15.     slow->next = delNode->next
  16.     delete delNode; 
  17.  
  18.     ListNode* retNode = dummyHead->next
  19.     delete dummyHead; 
  20.  
  21.     return retNode; 

java

  1. ListNode removeNthFromEnd(ListNode head, int n) { 
  2.     ListNode dummyHead = new ListNode(0); 
  3.     dummyHead.next = head; 
  4.     ListNode slow = dummyHead, fast = dummyHead; 
  5.     for (int i = 0; i < n + 1; ++i) { 
  6.         fast = fast.next
  7.     } 
  8.  
  9.     while (fast != null) { 
  10.         slow = slow.next
  11.         fast = fast.next
  12.     } 
  13.  
  14.     slow.next = slow.next.next
  15.     return dummyHead.next

 

責(zé)任編輯:武曉燕 來(lái)源: 程序員小熊
相關(guān)推薦

2021-08-10 07:57:03

算法鏈表倒數(shù)

2022-01-17 09:23:02

LeetCode刪除鏈表算法

2021-02-03 13:23:42

鏈表倒數(shù)結(jié)點(diǎn)

2020-10-19 13:27:19

鏈表倒數(shù)結(jié)點(diǎn)

2022-06-01 06:58:41

節(jié)點(diǎn)鏈表倒數(shù)

2023-04-17 07:33:11

反轉(zhuǎn)鏈表移除鏈表

2012-06-19 14:23:04

云計(jì)算中國(guó)

2021-02-04 08:18:53

LeetCode鏈表

2012-02-17 09:45:04

網(wǎng)速手機(jī)

2012-02-17 09:43:13

手機(jī)網(wǎng)速移動(dòng)互聯(lián)

2010-11-15 10:49:23

求職

2012-08-10 10:53:03

云計(jì)算BSA商業(yè)軟件聯(lián)盟

2012-06-18 10:07:17

云計(jì)算實(shí)力榜

2021-08-26 10:07:25

數(shù)組前端元素

2021-04-27 08:31:06

event loopJavaScriptsetTimeout函

2022-03-07 11:03:08

大數(shù)據(jù)檢測(cè)谷歌

2022-04-20 20:30:36

可視化模塊Python

2011-08-08 10:53:55

寶德PR2510N云計(jì)算

2018-03-01 13:32:28

宏碁游戲本PC行業(yè)

2021-09-22 22:57:41

手機(jī)流量通信
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲狠狠爱 | 国产视频二区在线观看 | 国产福利91精品一区二区三区 | av中文字幕在线 | 国产精品久久久久久久粉嫩 | 三级黄色片在线 | 久久久av | 久久久精品影院 | 人人鲁人人莫人人爱精品 | 在线观看黄色电影 | 日本字幕在线观看 | 国产精品久久国产精品 | 欧美精品一区二区免费 | 欧美二级| 亚洲综合精品 | 激情欧美一区二区三区中文字幕 | 一区二区视频免费观看 | 精品在线免费观看视频 | 久久宗合色 | 午夜爱爱毛片xxxx视频免费看 | 久久久久久久久淑女av国产精品 | 国产高清免费 | 久久久久国产一区二区三区四区 | 手机av在线 | 精品国产一区二区三区免费 | 久久精品成人 | 久久成人免费观看 | 精品久久亚洲 | 成人在线不卡 | 中文字幕一区二区三区在线乱码 | 日本一区二区三区免费观看 | 一级看片免费视频囗交动图 | 久久99精品国产 | 久久aⅴ乱码一区二区三区 亚洲国产成人精品久久久国产成人一区 | 中文成人无字幕乱码精品 | 极品销魂美女一区二区 | 久久亚洲一区 | 亚洲精品乱码 | 黄色网址免费看 | 久久久久久久久久毛片 | 欧美在线播放一区 |