go實現雙向鏈表

需求

實現雙向鏈表的節點生成、正反向遍歷、指定刪除。

實現

package mainimport ("fmt"
)type zodiac_sign struct {number   intdizhi    stringanimal   stringyear     intprevious *zodiac_signnext     *zodiac_sign
}// 添加
// func add_node_by_order(previous_node zodiac_sign, current_node zodiac_sign) zodiac_sign {
func add_node_by_order(previous_node *zodiac_sign, current_node *zodiac_sign) *zodiac_sign {if (previous_node.number + 1) == current_node.number {previous_node.next = current_nodefmt.Printf("節點%s的next指針已指向節點%s的地址%p\n", previous_node.animal, current_node.animal, previous_node.next)current_node.previous = previous_nodefmt.Printf("節點%s的previous指針已指向節點%s的地址%p\n", current_node.animal, previous_node.animal, current_node.next)return current_node} else {fmt.Printf("順序錯誤:禁止添加新節點%s\n", current_node.animal)return previous_node}
}// 正向查找
func check_node_positive(current_node *zodiac_sign) {if current_node.next == nil {fmt.Printf("正向:最后是%d年、%s年\n", current_node.year, current_node.animal)} else {fmt.Printf("正向:%d年為%s年\n", current_node.year, current_node.animal)check_node_positive(current_node.next)}
}// 反向查找
func check_node_negative(current_node *zodiac_sign) {if current_node.previous == nil {fmt.Printf("反向:最初是%d年、%s年\n", current_node.year, current_node.animal)} else {fmt.Printf("反向:%d年為%s年\n", current_node.year, current_node.animal)check_node_negative(current_node.previous)}
}// 刪除
func delete_node_by_id(current_node *zodiac_sign, id int) {if id < 1 || id > 12 {fmt.Print("輸入參數不在范圍內!\n")} else {if current_node.number == id {fmt.Printf("成功找到節點%s\n", current_node.animal)a := current_node.previous.animalb := current_node.next.animal// fmt.Printf("上一節點為%s、下一節點為%s\n", a, b)x := current_node.previousy := current_node.nextx.next = yy.previous = xfmt.Printf("節點%s的next指針已經指向%s,節點%s的previous指針已經指向%s", a, y.animal, b, x.animal)} else {delete_node_by_id(current_node.next, id)}}
}func main() {p := &zodiac_sign{}//var p *zodiac_signmouse := &zodiac_sign{number: 1, dizhi: "子", animal: "鼠", year: 2020}// var mouse zodiac_sign// mouse.number = 1// mouse.dizhi = "子"// mouse.animal = "鼠"// mouse.year = 2020cow := &zodiac_sign{number: 2, dizhi: "丑", animal: "牛", year: 2021}tiger := &zodiac_sign{number: 3, dizhi: "寅", animal: "虎", year: 2022}rabbit := &zodiac_sign{number: 4, dizhi: "卯", animal: "兔", year: 2023}dragon := &zodiac_sign{number: 5, dizhi: "辰", animal: "龍", year: 2024}snake := &zodiac_sign{number: 6, dizhi: "巳", animal: "蛇", year: 2025}horse := &zodiac_sign{number: 7, dizhi: "午", animal: "馬", year: 2026}sheep := &zodiac_sign{number: 8, dizhi: "未", animal: "羊", year: 2027}monkey := &zodiac_sign{number: 9, dizhi: "申", animal: "猴", year: 2028}cock := &zodiac_sign{number: 10, dizhi: "酉", animal: "雞", year: 2029}dog := &zodiac_sign{number: 11, dizhi: "戌", animal: "狗", year: 2030}pig := &zodiac_sign{number: 12, dizhi: "亥", animal: "豬", year: 2031}p = add_node_by_order(p, mouse)// fmt.Print(p)head := pp = add_node_by_order(p, cow)p = add_node_by_order(p, tiger)p = add_node_by_order(p, rabbit)p = add_node_by_order(p, dragon)p = add_node_by_order(p, snake)// 錯誤連接add_node_by_order(p, pig)p = add_node_by_order(p, horse)p = add_node_by_order(p, sheep)p = add_node_by_order(p, monkey)// 錯誤連接add_node_by_order(p, rabbit)p = add_node_by_order(p, cock)p = add_node_by_order(p, dog)p = add_node_by_order(p, pig)// fmt.Print(p)check_node_positive(head)check_node_negative(pig)delete_node_by_id(head, 5)
}
節點的next指針已指向節點鼠的地址0xc000030180
節點鼠的previous指針已指向節點的地址0x0       
節點鼠的next指針已指向節點牛的地址0xc0000301c0
節點牛的previous指針已指向節點鼠的地址0x0     
節點牛的next指針已指向節點虎的地址0xc000030200
節點虎的previous指針已指向節點牛的地址0x0     
節點虎的next指針已指向節點兔的地址0xc000030240
節點兔的previous指針已指向節點虎的地址0x0     
節點兔的next指針已指向節點龍的地址0xc000030280
節點龍的previous指針已指向節點兔的地址0x0
節點龍的next指針已指向節點蛇的地址0xc0000302c0
節點蛇的previous指針已指向節點龍的地址0x0
順序錯誤:禁止添加新節點豬
節點蛇的next指針已指向節點馬的地址0xc000030300
節點馬的previous指針已指向節點蛇的地址0x0
節點馬的next指針已指向節點羊的地址0xc000030340
節點羊的previous指針已指向節點馬的地址0x0
節點羊的next指針已指向節點猴的地址0xc000030380
節點猴的previous指針已指向節點羊的地址0x0
順序錯誤:禁止添加新節點兔
節點猴的next指針已指向節點雞的地址0xc0000303c0
節點雞的previous指針已指向節點猴的地址0x0
節點雞的next指針已指向節點狗的地址0xc000030400
節點狗的previous指針已指向節點雞的地址0x0
節點狗的next指針已指向節點豬的地址0xc000030440
節點豬的previous指針已指向節點狗的地址0x0
正向:2020年為鼠年
正向:2021年為牛年
正向:2022年為虎年
正向:2023年為兔年
正向:2024年為龍年
正向:2025年為蛇年
正向:2026年為馬年
正向:2027年為羊年
正向:2028年為猴年
正向:2029年為雞年
正向:2030年為狗年
正向:最后是2031年、豬年
反向:2031年為豬年
反向:2030年為狗年
反向:2029年為雞年
反向:2028年為猴年
反向:2027年為羊年
反向:2026年為馬年
反向:2025年為蛇年
反向:2024年為龍年
反向:2023年為兔年
反向:2022年為虎年
反向:2021年為牛年
反向:2020年為鼠年
反向:最初年是0年、年
成功找到節點龍
節點兔的next指針已經指向蛇,節點蛇的previous指針已經指向兔

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

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

相關文章

AI實踐指南:AGENT、RAG和MCP在Java中的簡單實現

在當今AI快速發展的時代&#xff0c;有幾個核心概念正在改變我們構建智能應用的方式。本文將用簡單易懂的語言介紹三個重要概念&#xff1a;AGENT&#xff08;AI代理&#xff09;、RAG&#xff08;檢索增強生成&#xff09;和MCP&#xff08;多通道感知&#xff09;&#xff0c…

解決VMware虛擬機能搜索到網頁但打不開的問題

&#x1f334; 問題描述 很奇怪&#xff0c;不知道為什么&#xff0c;我安裝的Windows 10虛擬機能在瀏覽器中搜索到網頁&#xff0c;但點擊具體的網頁鏈接就是死活不能加載出來&#xff0c;如下圖所示&#xff1a; 點擊第一個鏈接&#xff0c;加載了四五分鐘&#xff0c;結果就…

JVM性能調優的基礎知識 | JVM內部優化與運行時優化

目錄 JVM內部的優化邏輯 JVM的執行引擎 解釋執行器 即時編譯器 JVM采用哪種方式&#xff1f; 即時編譯器類型 JVM的分層編譯5大級別&#xff1a; 分層編譯級別&#xff1a; 熱點代碼&#xff1a; 如何找到熱點代碼&#xff1f; java兩大計數器&#xff1a; OSR 編譯…

什么是多租戶系統

隨著云計算和 SaaS&#xff08;Software as a Service&#xff09;模式的普及&#xff0c;多租戶架構&#xff08;Multi-Tenant Architecture&#xff09;成為 SaaS 產品設計中的核心模式之一。多租戶架構允許多個用戶&#xff08;租戶&#xff09;共享同一套基礎設施和應用&am…

多線程系列三:這就是線程的狀態?

1.認識線程的狀態 NEW&#xff1a;Thread對象已經創建好了&#xff0c;但還沒有調用start方法在系統中創建線程 RUNNABLE&#xff1a;就緒狀態&#xff0c;表示這個線程正在CPU上執行&#xff0c;或準備就緒&#xff0c;隨時可以去CPU上執行 BLOCKED&#xff1a;表示由于鎖競爭…

【C語言練習】019. 使用結構體數組存儲復雜數據

019. 使用結構體數組存儲復雜數據 019. 使用結構體數組存儲復雜數據示例1&#xff1a;定義一個結構體并創建結構體數組定義結構體創建并初始化結構體數組輸出結果 示例2&#xff1a;動態輸入數據到結構體數組定義結構體動態輸入數據示例輸入和輸出 示例3&#xff1a;使用結構體…

**Java面試大冒險:謝飛機的幽默與技術碰撞記**

互聯網大廠Java求職者面試&#xff1a;一場嚴肅與搞笑交織的技術盛宴 場景&#xff1a; 互聯網大廠面試間 人物&#xff1a; 面試官&#xff1a; 一位嚴肅的資深架構師&#xff0c;對技術要求嚴格。謝飛機&#xff1a; 一位搞笑的程序員&#xff0c;技術實力參差不齊。 第一…

MySQL進階(三)

五、鎖 1. 概述 鎖是計算機協調多個進程或線程并發訪問某一資源的機制&#xff08;避免爭搶&#xff09;。 在數據庫中&#xff0c;除傳統的計算資源&#xff08;如 CPU、RAM、I/O 等&#xff09;的爭用以外&#xff0c;數據也是一種供許多用戶共享的資源。如何保證數據并發…

【BLE】【nRF Connect】 精講nRF Connect自動化測試套件(宏錄制、XML腳本)

目錄 前言 1. nRF Connect自動化測試介紹 1.1. nRF connect宏錄制功能介紹 1.2. 電腦端XML方式 1.3 實際應用案例 1.3.1 BLE 穩定性測試 1.3.2 設備固件更新(DFU)測試 1.3.3 批量設備配置 1.4 操作步驟 1.5 注意事項 2. nRF Connect日志記錄 2.1. 日志記錄功能 …

【數據結構】堆的完整實現

堆的完整實現 堆的完整實現GitHub地址前言堆的核心功能實現重溫堆的定義堆結構定義1. 堆初始化與銷毀2. 元素交換函數3. 堆化操作向上調整&#xff08;子→父&#xff09;向下調整&#xff08;父→子&#xff09; 4. 堆元素插入5. 堆元素刪除6. 輔助功能函數堆的判空獲取堆頂元…

如何優化MySQL主從復制的性能?

優化MySQL主從復制的性能需要從硬件、配置、架構設計和運維策略等多方面入手。以下是詳細的優化方案&#xff1a; 一、減少主庫寫入壓力 1. ?主庫優化? 二進制日志&#xff08;binlog&#xff09;優化?&#xff1a; 使用 binlog_formatROW 以獲得更高效的復制和更少的數…

MySQL安裝完全指南:從零開始到配置優化(附避坑指南)

&#x1f525; 前言&#xff1a;為什么你總是裝不好MySQL&#xff1f; &#xff08;實話實說&#xff09;每次看到新手在MySQL安裝環節瘋狂踩坑&#xff0c;老司機都忍不住想摔鍵盤&#xff01;明明官網下載的安裝包&#xff0c;怎么就會報錯呢&#xff1f;為什么別人的環境變…

密碼學_加密

目錄 密碼學 01 密碼基礎進制與計量 02 加解密基操 替換 移位 編碼 編碼 置換 移位 加解密強度 03 對稱加密算法(私鑰) 工作過程 缺陷 對稱加密算法列舉&#xff1f; DES DES算法架構 DES分組加密公式 DES中ECB-CBC兩種加密方式 3DES 由于DES密鑰太短&#xf…

輕量級RTSP服務模塊:跨平臺低延遲嵌入即用的流媒體引擎

在音視頻流媒體系統中&#xff0c;RTSP&#xff08;Real-Time Streaming Protocol&#xff09;服務模塊通常扮演著“視頻分發中心”的角色&#xff0c;它將編碼后的音視頻內容轉為標準的流媒體格式&#xff0c;供客戶端&#xff08;播放器、云端平臺、AI模塊等&#xff09;拉流…

Nginx發布Vue(ElementPlus),與.NETCore對接(騰訊云)

案例資料鏈接&#xff1a;https://download.csdn.net/download/ly1h1/90745660 1.邏輯說明 1.1 邏輯示意圖 # 前端請求處理邏輯圖瀏覽器請求流程: 1. 瀏覽器發起請求├─ 開發環境(DEV)│ ├─ 請求URL: http://192.168.0.102:3000/api/xxx│ └─ 被Vite代理處理└─ 生產…

解析機器人 2.0.2 | 支持超過50種短視頻平臺的鏈接解析,無水印提取,多功能下載工具

解析機器人是一款功能強大的工具軟件&#xff0c;登錄即可解鎖會員特權。它支持超過50種短視頻平臺的鏈接解析&#xff0c;包括抖音、快手、西瓜、bilibili等&#xff0c;并能實現無水印提取。此外&#xff0c;還提供P2P下載、磁力鏈等多種下載方式&#xff0c;確保用戶能夠快速…

C++ - 數據容器之 forward_list(創建與初始化、元素訪問、容量判斷、元素遍歷、添加元素、刪除元素)

一、創建與初始化 引入 <forward_list> 并使用 std 命名空間 #include <forward_list>using namespace std;創建一個空 forward_list forward_list<int> fl;創建一個包含 5 個元素&#xff0c;每個元素初始化為 0 的 forward_list forward_list<int&g…

Python爬蟲實戰:獲取企信網指定公司基本工商數據并分析,為客戶選擇公司做參考

一、引言 在商業決策、市場調研等眾多領域,企業的基本工商信息是至關重要的參考依據。企信網作為權威的企業信息查詢平臺,匯聚了海量企業的詳細信息。借助 Python 的爬蟲技術,能夠自動從企信網獲取指定公司的工商信息,再運用數據分析和機器學習方法對這些信息進行深入挖掘…

STM32部分:2-1、STM32CubeMX介紹

飛書文檔https://x509p6c8to.feishu.cn/wiki/BTv4wW3O7ita1dkQGkrcBb9rnXg 資料手冊 英文手冊 https://www.stmcu.com.cn/Designresource/detail/user_manual/711316 中文手冊 https://www.stmcu.com.cn/Designresource/detail/localization_document/710583 界面說明 首…

SVM實戰:從理論到鳶尾花數據集的分類可視化

SVM實戰&#xff1a;從理論到鳶尾花數據集的分類可視化 在機器學習的廣闊領域中&#xff0c;支持向量機&#xff08;Support Vector Machine&#xff0c;SVM&#xff09;作為一種經典且強大的分類算法&#xff0c;備受矚目。它憑借獨特的思想和卓越的性能&#xff0c;在模式識…