leetcode 19 刪除鍊錶的倒數第N個節點

2021-10-24 21:46:38 字數 1074 閱讀 1333

先求出長度,再找到要刪除的那個節點的前乙個節點。

//鍊錶 1->2->3->4->5

//需要刪除倒數第2個,就是刪除順數第4個,需要找到順數第3個,5-2=3,

//需要刪除倒數第1個,就是刪除順數第5個,需要找到順數第4個,5-1=4,

//需要刪除倒數第2個,就是刪除順數第4個,需要找到順數第3個,5-2=3,

//需要刪除倒數第5個,就是刪除順數第1個,需要找到順數第0個,5-5=0。

int index = length - n;

if(index==0)

curr = head;

for(

int i=

1;i) curr.next = curr.next.next;

return head;

}}以下**為c語言寫的。

/**

* definition for singly-linked list.

* struct listnode ;

*/struct listnode*

removenthfromend

(struct listnode* head,

int n)

while

(first)

second->next = second->next->next;

struct listnode* ans = dummy->next;

free

(dummy)

;return ans;

}

LeetCode 19 鍊錶(160)

1 如圖,鍊錶是一種非常常用的資料結構 煉表頭 指向第乙個鍊錶結點的指標 鍊錶結點 鍊錶中的每乙個元素,包括 1 當前結點的資料,2 下乙個結點的位址 鍊錶尾 不再指向其他結點的結點,其位址部分放乙個null,表示鍊錶到此結束。2 鍊錶可以動態地建立 動態地申請記憶體空間 int pint new ...

鍊錶 LeetCode19刪除鍊錶中的第N個節點

給定乙個鍊錶,刪除鍊錶的倒數第 n 個節點,並且返回鍊錶的頭結點。示例 給定乙個鍊錶 1 2 3 4 5,和 n 2.當刪除了倒數第二個節點後,鍊錶變為 1 2 3 5.說明 給定的 n 保證是有效的。高階 你能嘗試使用一趟掃瞄實現嗎?分析 看到這個問題,第一反應,先求長度,再找節點,看一下高階,有...

Leetcode 19 刪除鍊錶的第N個節點

給定乙個鍊錶,刪除鍊錶的倒數第 n 個節點,並且返回鍊錶的頭結點。示例 給定乙個鍊錶 1 2 3 4 5,和 n 2.當刪除了倒數第二個節點後,鍊錶變為 1 2 3 5.說明 給定的 n 保證是有效的。高階 你能嘗試使用一趟掃瞄實現嗎?兩次遍歷的演算法思路 第一遍歷從頭結點開始來計算鍊錶的長度,然後...