golang使用链表实现简单list

package main
import (
	"fmt"
)

type Node struct {
	element int
	next *Node
}

type List struct {
	len int
	head *Node
	tail *Node
}

func LinkList() *List  {
	list:=new(List)
	tail:=new(Node)
	list.tail=tail
	list.head=tail
	return list
}

func (list *List)append(e int)  {
	node:=new(Node)
	node.element=e
	list.head.next = node
	list.head=node
	list.len ++
}

func (list *List) get(index int) int{

	var node  *Node
	node=list.tail
	for i:=0 ;i<=index ; i++{
		node=node.next
		if node == nil{
			return 0
		}
	}
	return node.element
}
func (list *List) getNode(index int) *Node{
	var node  *Node
	node=list.tail
	for i:=0 ;i<=index ; i++{
		node=node.next
	}
	return node
}

func (list *List)remove(index int) interface{} {
	var prev,current,next *Node
	prev=list.tail
	for i:=0;i<index ;i++  {
		prev=prev.next
	}
	current=prev.next
	next=current.next
	if list.len == index+1{
		list.head=prev
		prev.next=nil
	}else {
		prev.next=next
		list.head=next
	}
	list.len--
	return current.element
}

func main() {
	list:=LinkList()
	list.append(10)
	fmt.Println(list.get(0))
	a:=list.remove(0)
	fmt.Println(a)
	list.append(20)
	list.append(11)
	list.append(114)
	list.append(115)
	list.append(181)
	list.append(4)
	b:=list.remove(list.len-1)
	fmt.Println(b)
	fmt.Println(list.get(0),list.len)
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值