Go程序员面试算法宝典-读后感2-链表
2024-10-21 16:40:15
链表作为最基本的数据结构,它不仅仅在实际应用中有着非常重要的作用,而且也是程序员面试笔试必考的内容。
详情请Google吧。
1、如何实现链表的逆序
就地逆序
package main import (
"fmt"
_ "fmt"
_ "github.com/ha666/golibs"
."github.com/isdamir/gotype" //引入定义的数据结构 ) //带头结点的逆序
func Reverse(node *LNode) { if node ==nil||node.Next==nil {
return
}
var pre *LNode //定义前驱结点
var cur *LNode //定义当前结点
next:=node.Next //定义后继结点 for next!=nil {
cur=next.Next
next.Next=pre
pre=next
next=cur
}
node.Next=pre
} func main() {
head :=&LNode{}
fmt.Println("就地逆序")
CreateNode(head,)
PrintNode("逆序前:",head)
Reverse(head)
PrintNode("逆序后:",head)
}
//就地逆序
//逆序前:1 2 3 4 5 6 7 8 9 10
//逆序后:10 9 8 7 6 5 4 3 2 1 ////创建链表
//func CreateNode(node *LNode, max int) {
// cur := node
// for i := 1; i < max+1; i++ {
// cur.Next = &LNode{}
// cur.Next.Data = i
// cur = cur.Next
// }
//}
最新文章
- [译] EXTENDING JQUERY &ndash; 2.2 A simple plugin
- Hibernate学习笔记之EHCache的配置
- Hadoop序列化
- wince下sources\sources.cmn\Makefile.def的相关作用
- uva 1482 - Playing With Stones
- RHEL6.4编译安装gcc4.8.1
- linux修改环境变量
- CROW-5 WEB APP引擎商业计划书(HTML5方向)-微信网页版微信公众平台登录-水仙谷
- 关于C语言中有string类型吗?
- javascript - Get page source code - Stack Overflow
- JS中const、var 和let的区别
- 我的python渗透测试工具之主机嗅探
- 【Ueditor】富文本编辑使用
- 转载 使用axis2构建webservice
- So you want to be a computational biologist?
- leaks工具查找内存泄露
- java的关于流程结构做的几个案例
- 3.3 x86指令简介
- .Net EF Core数据库使用SQL server 2008 R2分页报错How to avoid the “Incorrect syntax near &#39;OFFSET&#39;. Invalid usage of the option NEXT in the FETCH statement.”
- Linux服务-samba