当前位置: 首页 > news >正文

郑州市人民政府合肥seo招聘

郑州市人民政府,合肥seo招聘,做旅游网站的研究意义,网站 提交入口文章目录 链表的相关知识链表的创建:模拟方式建立链表的**递归创建** 链表的读取遍历读取递归读取 完整代码 链表的相关知识 链表有时会具有头节点,头节点的指针指向第一个节点的地址,其本身的数据域可以根据自己的选择进行赋值   接下来我将以将int转…

文章目录

  • 链表的相关知识
    • 链表的创建:
      • 模拟方式建立
      • 链表的**递归创建**
    • 链表的读取
      • 遍历读取
      • 递归读取
    • 完整代码

链表的相关知识

  链表有时会具有头节点,头节点的指针指向第一个节点的地址,其本身的数据域可以根据自己的选择进行赋值
  接下来我将以将int转换为链表为例进行演示,如果有什么地方可以改进,也希望路过大神能够指出

链表的创建:

链表的结构定义一般如下,即由本身的数据和指向下一个节点的指针构成

type ListNode struct {Val  intNext *ListNode//不能直接赋值listnode,避免产生嵌套引用
}

  链表的创建(每个节点存储一位数字),在创建的过程中 我们需要设置中间的可变节点,不然我们可能会丢失对链表的第一个节点的索引,以下的例子中我们就使用middle为中间节点;将head设置为头节点,并代表完整的链表

模拟方式建立

  我们利用迭代的方法,只要还存在num,就更新创建一个新的节点

// 尝试建立有头节点的链表,关键在于赋值给middle.next
func CreateList(nums int) *ListNode {Head := new(ListNode) //这代表一整个链表,并通过这里的头节点进行标注,方便该链表的引用middle := Head //middle视作Head链表的中间节点,其一直改变for nums > 0 {middle.Next = &ListNode{Val: nums % 10}//头节点赋值方法fmt.Printf("middle.Val: %v\n", middle.Val)middle = middle.Nextnums /= 10}return Head
}

链表的递归创建

// 递归建立链表
func RecurCreateList(nums int) *ListNode {//在递归时好像不需要单独保存头节点位置,后续的位置会递归存储在next中,不用考虑被覆盖的问题middle := new(ListNode) //建立头指针,其指针不变// 123%10=3// 12.3%10=2// 1.23%10=1// 120%10=0// 12 %10=2// 1.2%10=1if nums > 1 || nums%10 > 0 {middle.Val = nums % 10fmt.Printf("middle.Val: %v\n", middle.Val)if nums > 1 {nums /= 10middle.Next = RecurCreateList(nums)}}return middle
}

链表的读取

遍历读取

  链表读取时我们需要根据是否具有头节点进行一定的调整,下面是使用遍历(迭代)进行创建的过程

// 尝试遍历读取链表
func ReadList(L ListNode) {middle := L //将头节点赋予这里的中间节点middle//循环读取链表的内容for middle.Next != nil {v := middle.Next.Val //由于我们这里判断的是本身节点是否为空,所以在输出时使用下一节点的值进行输出,避免错过某个值fmt.Printf("v: %v\n", v)// 	// fmt.Printf("L: %v\n", L)middle = *middle.Next// 	// fmt.Printf("L: %v\n", L)}
}

递归读取

下面为使用递归进行读取的方法
由于节点的定义过程中使用内嵌,在建立相关函数时都使用指针比较方便[ 虽然前面都没注意:( ],

// 尝试递归读取链表
func RecurReadList(L *ListNode) {fmt.Printf("L.Val: %v\n", L.Val) //打印出此节点中的Val//如果本结点的指针不为空,即还有下一个节点,继续读取if L.Next != nil {RecurReadList(L.Next) //将下个节点的指针传入}//如果运行到这里,说明指针为空,函数也就到此结束了
}

完整代码

package mainimport ("fmt"
)type ListNode struct {Val  intNext *ListNode
}func main() {// l := CreateList(13)l := RecurCreateList(13)fmt.Printf("l: %v\n", *l)// ReadList(*l)RecurReadList(l)// RecurReadList(l.Next)// fmt.Println(l.Next.Val)
}// 尝试建立有头节点的链表,关键在于赋值给middle.next
func CreateList(nums int) *ListNode {Head := new(ListNode) //这代表一整个链表,并通过这里的头节点进行标注,方便该链表的引用middle := Head //middle视作Head链表的中间节点,其一直改变for nums > 0 {middle.Next = &ListNode{Val: nums % 10} //头节点赋值方法fmt.Printf("middle.Val: %v\n", middle.Val)middle = middle.Nextnums /= 10}return Head
}// 递归建立链表
func RecurCreateList(nums int) *ListNode {//在递归时好像不需要单独保存头节点位置,后续的位置会递归存储在next中,不用考虑被覆盖的问题middle := new(ListNode) //建立头指针,其指针不变// 123%10=3// 12.3%10=2// 1.23%10=1// 120%10=0// 12 %10=2// 1.2%10=1if nums > 1 || nums%10 > 0 {middle.Val = nums % 10fmt.Printf("middle.Val: %v\n", middle.Val)if nums > 1 {nums /= 10middle.Next = RecurCreateList(nums)}}return middle
}// 尝试遍历读取链表
func ReadList(L ListNode) {middle := L //将头节点赋予这里的中间节点middle//循环读取链表的内容for middle.Next != nil {v := middle.Next.Val //由于我们这里判断的是本身节点是否为空,所以在输出时使用下一节点的值进行输出,避免错过某个值fmt.Printf("v: %v\n", v)// 	// fmt.Printf("L: %v\n", L)middle = *middle.Next// 	// fmt.Printf("L: %v\n", L)}
}// 尝试递归读取链表
func RecurReadList(L *ListNode) {fmt.Printf("L.Val: %v\n", L.Val) //打印出此节点中的Val//如果本结点的指针不为空,即还有下一个节点,继续读取if L.Next != nil {RecurReadList(L.Next) //将下个节点的指针传入}//如果运行到这里,说明指针为空,函数也就到此结束了
}
http://www.shuangfujiaoyu.com/news/47797.html

相关文章:

  • 深圳网站建设工作写软文
  • 沈阳哪家做网站好郴州网络推广公司排名
  • php商城建站系统地推拉新app推广平台有哪些
  • 汽修网站怎么做网站制作的要点和步骤详解
  • 单页网站建设哪里有提供四川疫情最新消息
  • 德州网页设计师培训百度快速优化排名软件
  • 网站关闭流程seo和sem是什么意思啊
  • 网站需求分析的重要seo排名点击报价
  • 学生网上兼职网站seo外包公司怎么样
  • 有自己的域名怎么建立网站企业培训课程安排表
  • wordpress百度音乐太原seo哪家好
  • 我的网站为什么打不开怎么做好网站方式推广
  • 企业网站建设的推广方式中国建设网官方网站
  • 微管家里的微网站怎么建设地推接单平台
  • 饰品网站模版淘宝网店的seo主要是什么
  • wordpress安装完怎么用优化设计五年级上册语文答案
  • 学做网站的基本百度网盘网页版登录
  • 海南专业做网站的公司巩义网络推广公司
  • 企业网站 app什么软件可以推广
  • b2c的电子信息网站新闻今日头条最新消息
  • wordpress文章结构郑州seo排名公司
  • 奉贤集团公司网站建设网站怎么优化关键词排名
  • 网站视频封面怎么做官方百度平台
  • 网站做404网络优化工程师主要负责什么工作
  • 做批发的在什么网站拿货网络公司的推广
  • 网站建设中 windowsaso推广平台
  • 企业网站搜索引擎优化方案电商运营基本知识
  • 无锡微信手机网站制作无锡谷歌推广
  • 外网常用网站搜索引擎营销的主要方式有哪些?
  • 网站留言程序怎么做站长工具seo综合查询是什么