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

LeetCode題解之刪除鏈表倒數第n個結點

開發 前端
再想想,可不可以不計算鏈表長度呢?也就是題目上所說的進階解法,用一次掃描。再鏈表中,有一種常用的方法,叫做快慢指針,意思就是用到兩個速度不同的指針解決一些問題。

[[380272]]

前言

今天繼續說鏈表常見問題中的——刪除鏈表倒數第n個結點:

  • 單鏈表反轉
  • 兩個有序的鏈表合并
  • 刪除鏈表倒數第n個結點
  • 求鏈表的中間結點
  • 鏈表中環的檢測

題目:刪除鏈表倒數第n個結點

給你一個鏈表,刪除鏈表的倒數第 n 個結點,并且返回鏈表的頭結點。

進階:你能嘗試使用一趟掃描實現嗎?

示例 1:輸入:head = [1,2,3,4,5], n = 2 輸出:[1,2,3,5]

示例 2:輸入:head = [1], n = 1 輸出:[]

示例 3:輸入:head = [1,2], n = 1 輸出:[1]

解法一

首先容易想到的辦法就是想數組一樣,遍歷鏈表找到那個要被刪除的結點,所以先解決兩個問題:

1、獲取鏈表的總長度

  1. public int getLength(ListNode head){ 
  2.         int n=0; 
  3.         while(head!=null){ 
  4.             n++; 
  5.             head=head.next
  6.         } 
  7.         return n; 
  8.     } 

2、找到結點之后,怎么刪除。

其實就是把next指向跨過去要刪除的結點就行了。

  1. tempNode.next=tempNode.next.next

但是,上述這個方法是刪除的tempNode.next結點,如果我們要刪除tempNode本身這個結點,那么就要把一開始的結點提前到第一個結點之前。

比如我們要刪除鏈表的第一個結點,如果你本身的指針就指向第一個結點,那么通過上面這個刪除方法就永遠刪除不了第一個結點了。

所以要把指針提前到第一個結點之前。

所以,綜上所述,我們得出以下解法:

  1. /** 
  2.  * Definition for singly-linked list. 
  3.  * public class ListNode { 
  4.  *     int val; 
  5.  *     ListNode next
  6.  *     ListNode() {} 
  7.  *     ListNode(int val) { this.val = val; } 
  8.  *     ListNode(int val, ListNode next) { this.val = val; this.next = next; } 
  9.  * } 
  10.  */ 
  11. class Solution { 
  12.     public ListNode removeNthFromEnd(ListNode head, int n) { 
  13.         int length=getLength(head); 
  14.         //新建一個新的鏈表結點指向head頭結點,也就是上面要注意的特殊情況 
  15.         ListNode lastNode=new ListNode(0,head); 
  16.         ListNode tempNode=lastNode; 
  17.         for(int i=0;i<length-n;i++){ 
  18.             tempNode=tempNode.next
  19.         } 
  20.         tempNode.next=tempNode.next.next
  21.         return lastNode.next
  22.     } 
  23.  
  24.     public int getLength(ListNode head){ 
  25.         int n=0; 
  26.         while(head!=null){ 
  27.             n++; 
  28.             head=head.next
  29.         } 
  30.         return n; 
  31.     } 

時間復雜度

用到了遍歷、時間復雜度為O(n)

空間復雜度

只用到幾個單獨的鏈表結點,所以空間復雜度為O(1)

解法二

再想想,可不可以不計算鏈表長度呢?也就是題目上所說的進階解法,用一次掃描。

再鏈表中,有一種常用的方法,叫做快慢指針,意思就是用到兩個速度不同的指針解決一些問題。

比如這個題中,我們使用一個快指針一個慢指針,并且讓快指針快n個結點,然后兩個指針一直往后移動。當快指針移動到結尾,那么慢指針的位置就是我們要刪除的結點了。

當然,這里也要考慮到當前結點被刪除的情況,所以要把開始結點提前到鏈表之前。

  1. public ListNode removeNthFromEnd(ListNode head, int n) { 
  2.  //提前鏈表 
  3.         ListNode LastNode=new ListNode(0,head); 
  4.         ListNode FirstNode=LastNode; 
  5.         ListNode SecondNode=head; 
  6.         for(int i=0;i<n;i++){ 
  7.             SecondNode=SecondNode.next
  8.         } 
  9.  
  10.         while(SecondNode!=null){ 
  11.             FirstNode=FirstNode.next
  12.             SecondNode=SecondNode.next
  13.         } 
  14.  
  15.         FirstNode.next=FirstNode.next.next
  16.          
  17.         return LastNode.next
  18.     } 

時間復雜度

時間復雜的為O(n)

空間復雜度

空間復雜度為O(1)

其他解法

還有其他的解法,比如用到棧先進后出的原則,先把所有鏈表數據入棧,然后出棧n個數。剩下的棧頂就是要刪除結點的前驅結點了,然后調用上述的刪除結點方法,就可以刪除要刪除的下個結點了。

參考

https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list/

本文轉載自微信公眾號「碼上積木」,可以通過以下二維碼關注。轉載本文請聯系碼上積木公眾號。

 

責任編輯:武曉燕 來源: 碼上積木
相關推薦

2022-01-17 09:23:02

LeetCode刪除鏈表算法

2021-08-10 07:57:03

算法鏈表倒數

2021-04-14 10:19:18

鏈表倒數結點

2020-10-19 13:27:19

鏈表倒數結點

2021-02-04 08:18:53

LeetCode鏈表

2022-06-01 06:58:41

節點鏈表倒數

2023-04-17 07:33:11

反轉鏈表移除鏈表

2021-01-21 08:23:29

鏈表單鏈表循環鏈表

2021-01-28 08:20:41

鏈表空間復雜度

2022-02-16 09:12:22

LeetCode升序鏈表鏈表數組

2012-06-19 14:23:04

云計算中國

2021-03-12 08:19:20

數組跳躍游戲

2018-03-01 13:32:28

宏碁游戲本PC行業

2012-02-17 09:45:04

網速手機

2012-02-17 09:43:13

手機網速移動互聯

2021-01-22 08:30:50

LeetCode數字數組

2021-03-22 08:23:29

LeetCode二叉樹節點

2012-08-10 10:53:03

云計算BSA商業軟件聯盟

2012-06-18 10:07:17

云計算實力榜

2019-11-01 11:19:25

轉鏈表LeetCode代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲三级在线观看 | 91精品国产乱码麻豆白嫩 | 成人一区av偷拍 | 久久久夜 | www.久草.com | 日韩免费av| 国产视频一区二区在线观看 | 亚洲网站在线观看 | 色噜噜狠狠色综合中国 | 国产露脸对白88av | 亚洲精久久| 午夜激情影院 | 一本色道久久综合亚洲精品高清 | 欧美男人天堂 | 欧美激情亚洲 | 国内在线视频 | 日本大香伊一区二区三区 | 国产精品久久久久久久午夜片 | 北条麻妃一区二区三区在线视频 | 亚洲一区二区三区免费在线 | 日韩在线播放第一页 | av在线免费播放 | 国产99免费视频 | 国产91丝袜在线18 | 国产一区二区三区四区 | 亚洲精品一区二区在线观看 | 美女久久久久久久久 | 日韩成年人视频在线 | 九一精品| 日韩成人在线视频 | 日韩天堂av | a级片在线观看 | 99久久精品免费看国产四区 | 日本久草| 日韩精品成人一区二区三区视频 | 亚洲成在线观看 | 一级毛片高清 | 中文字幕精品一区二区三区精品 | 色综合成人网 | 91亚洲精选 | 91精品久久久久久久久中文字幕 |