golang 遍历list_Golang中List的实现方法示例详解

本文介绍了如何在Golang中实现List数据结构,包括初始化List、定义Node结构、创建List对象、判断List是否为空及获取长度、头插法与尾插法、查找元素、删除元素以及遍历List的方法。通过这些实现,可以深入理解Go语言的特性和语法。
摘要由CSDN通过智能技术生成

前言

为了快速回顾Go基本的语法知识,打算用Go中的基本语法以及特性来实现一些常见的数据结构和排序算法,通过分析如何实现一些基本的数据结构,可以很快学习Go的语法特性。记忆更加深刻,掌握更加迅速。这是我认为学习一门新语言入门最好的方式。这也是方便自己以后需要用Go来写东西的一种前期准备,到时候就不用去翻一些教程了。系列博文的第一篇就从如何实现List开始。

需求

大家都知道基本链表得有以下特性:链表的初始化、链表的长度、节点的插入、删除、查找等一些常见的基本操作,最后写好之后,需要测试。关于测试,我之前写过Go的系列笔记中有叙述,不再重复。

实现

初始化

有语言基础的人都知道,链表是由节点连接而成,这其中在定义一个List数据结构之外,还需要定义一个Node类型的数据结构。先说Node类型的数据结构,首先List按照正常的设计应该是可以存储基本类型的数据的,这就要求Node中的Value至于的类型不能固定,此时你可能反驳道:在Java中我们不是可以传入Int、String类型到List吗?其实这就是在走偏了,现在的工作是实现List这种数据结构。所以不能对其Value值域有任何类型限制,在Go中'空接口'恰好能够满足这种须需求。另外在List中一个Node需要两个指针域,分别指向前后节点的地址。在Go中这种需求,可以通过 *来实现,简单理解为其可以存储地址。如*Int就是int类型的地址。看实现方式:

type Node struct {

Value interface{}

next, prev *Node

}

下面就是定义List结构体了&

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值