分享
  1. 首页
  2. 文章

重温一遍数据结构之单链表(golang版)

woshicixide · · 8557 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

说明

上一篇说的是线性表中的顺序存储结构,他的读取复杂度虽然是o(1),但是它的缺点也很明显,插入和删除需要移动很多元素,而且需要分配一块连续的内存区域

线性表之单链表

单链表在一定程度上解决了一部分上面的问题,而且也不要一大块连续的内存区域,代码如下

package main
//线性表中的链式存储结构
//第一个节点为头节点,并不真实保存数据,头节点基本代表了整个链表
import (
 "fmt"
)
type Elem int
type LinkNode struct {
 Data Elem
 Next *LinkNode
}
//生成头节点
func New() *LinkNode {
 //下面的data可以用来表示链表的长度
 return &LinkNode{0, nil}
}
//在链表的第i个位置前插入一个元素e,复杂度为o(n)
func (head *LinkNode) Insert(i int, e Elem) bool {
 p := head
 j := 1
 for nil != p && j < i {
 p = p.Next
 j++
 }
 if nil == p || j > i {
 fmt.Println("pls check i:", i)
 return false
 }
 s := &LinkNode{Data: e}
 s.Next = p.Next
 p.Next = s
 return true
}
//遍历链表
func (head *LinkNode) Traverse() {
 point := head.Next
 for nil != point {
 fmt.Println(point.Data)
 point = point.Next
 }
 fmt.Println("--------done----------")
}
//删除链表中第i个节点,复杂度为o(n)
func (head *LinkNode) Delete(i int) bool {
 p := head
 j := 1
 for (nil != p && j < i) {
 p = p.Next
 j++
 }
 if nil == p || j > i {
 fmt.Println("pls check i:", i)
 return false
 }
 p.Next = p.Next.Next
 return true
}
// 获取链表中的第i个元素,复杂度为o(n)
func (head *LinkNode) Get(i int) Elem {
 p := head.Next
 for j:= 1; j< i ;j++ {
 if nil == p {
 //表示返回错误
 return -100001
 }
 p=p.Next
 }
 return p.Data
}
func main() {
 linkedList := New()
 linkedList.Insert(1, 9)
 linkedList.Insert(1, 99)
 linkedList.Insert(1, 999)
 linkedList.Insert(1, 9999)
 linkedList.Insert(1, 99999)
 linkedList.Insert(1, 999999)
 linkedList.Traverse()
 linkedList.Delete(4)
 linkedList.Traverse()
 e := linkedList.Get(4)
 fmt.Println(e)
}

有疑问加站长微信联系(非本文作者)

本文来自:Segmentfault

感谢作者:woshicixide

查看原文:重温一遍数据结构之单链表(golang版)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
8557 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏