前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Go程序员面试算法宝典-读后感2-链表

Go程序员面试算法宝典-读后感2-链表

作者头像
landv
发布2019-06-21 14:55:23
7980
发布2019-06-21 14:55:23
举报
文章被收录于专栏:landvlandv

链表作为最基本的数据结构,它不仅仅在实际应用中有着非常重要的作用,而且也是程序员面试笔试必考的内容。

详情请Google吧。

1、如何实现链表的逆序

就地逆序

代码语言:javascript
复制
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,10)
    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
//    }
//}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-06-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档