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.mzph.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;在模式识…