go語言如何刪除鍊錶節點
Jan 06, 2021 pm 01:45 PM
go語言
節點
鍊錶
go語言刪除鍊錶節點的方法:先將下一個節點的值移到目前刪除節點;然後再更改目前節點的Next即可,如【node.Next = node.Next.Next】。
本文操作環境:windows10系統、GO 1.11.2、thinkpad t480電腦。
具體方法:
最佳解:
把下一個節點的值移到目前刪除節點,然後變更目前節點的Next
node.Val = node.Next.Val node.Next = node.Next.Next
登入後複製
其他方法:
p.next = p.next.next即可達到刪除的目的
/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */ func deleteNode(head *ListNode, val int) *ListNode { if head.Val == val{ return head.Next } pre:=head for head.Next.Val != val{ head = head.Next } head.Next = head.Next.Next return pre }
登入後複製
題目:
刪除鍊錶中的節點
請寫一個函數,使其可以刪除某個鍊錶中給定的(非末尾)節點,你將只被給定要求被刪除的節點。
現有一個鍊錶– 頭 = [4,5,1,9],它可以表示為:
範例1:
輸入: head = [4,5,1,9], node = 5
輸出: [4,1,9]
解釋: 給定你鍊錶中值為5 的第二個節點,那麼在呼叫了你的函數之後,該鍊錶應變為4 -> 1 -> 9.
範例2:
#輸入: head = [4,5,1,9], node = 1
輸出: [4,5,9]
解釋: 給定你鍊錶中值為1 的第三個節點,那麼在呼叫了你的函數之後,該鍊錶應變為4 -> 5 -> 9.
Code
依然注意,是達到刪除的目的
/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */ func deleteNode(node *ListNode) { for node.Next.Next != nil { node.Val = node.Next.Val node = node.Next } node.Val = node.Next.Val node.Next = nil }
登入後複製
相關推薦:golang教學
以上是go語言如何刪除鍊錶節點的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)