go语言实现【队列】|二叉树的【先序遍历】【创建】

简介: go语言实现【队列】|二叉树的【先序遍历】【创建】

正文


简介go语言实现【队列】|二叉树的【先序遍历】【创建】


一 go语言实现队列#


var q Queue
func initQueue() *Queue {
  if q.nodeList == nil {
    q = Queue{}
    q.new()
  }
  return &q
}
type Queue struct {
  nodeList [] *BiTreeNode
}
type IQueue interface {
  new() *Queue
  enqueue(node *BiTreeNode)
  dequeue() *BiTreeNode
  isEmpty() bool
  size() int
}
func (q *Queue) new() *Queue {
  q.nodeList = []*BiTreeNode{}
  return q
}
func (q *Queue) enqueue(node *BiTreeNode) {
  q.nodeList = append(q.nodeList, node)
}
func (q *Queue) dequeue() *BiTreeNode {
  if 0 == len(q.nodeList) {
    return nil
  } else {
    item := q.nodeList[0]
    q.nodeList = q.nodeList[1:len(q.nodeList)]
    return item
  }
}
func (q *Queue) isEmpty() bool {
  return len(q.nodeList) == 0
}
func (q *Queue) size() int {
  return len(q.nodeList)
}


二 go语言实现创造二叉树#


func createBiTree(nodes [] int) *BiTreeNode {
  //var root BiTreeNode
  if nil != nodes && 0 != len(nodes) {
    root := BiTreeNode{}
    root.val = nodes[0]
    //nodes = nodes[1:len(nodes)]
    q := initQueue()
    q.enqueue(&root)
    var len int = len(nodes)
    for i := 1; i < len; {
      temp := q.dequeue()
      if -1 != nodes[i] {
        left := BiTreeNode{}
        left.val = nodes[i]
        q.enqueue(&left)
        temp.left = &left
      }
      i++
      if -1 != nodes[i] {
        right := BiTreeNode{}
        right.val = nodes[i]
        q.enqueue(&right)
        temp.right = &right
      }
      i++
    }
    return &root
  }
  return nil
}


结构#


12.jpg


三 先序遍历二叉树#


func preOrderBiTree(root *BiTreeNode) {
  if nil != root {
    fmt.Println((*root).val)
    preOrderBiTree((*root).left)
    preOrderBiTree((*root).right)
  }
}


四 其他信息#


二叉树的节点信息


type BiTreeNode struct {
  val   int
  left  *BiTreeNode
  right *BiTreeNode
}
相关文章
|
4天前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
52 20
|
2天前
|
存储 监控 算法
探秘员工泄密行为防线:基于Go语言的布隆过滤器算法解析
在信息爆炸时代,员工泄密行为对企业构成重大威胁。本文聚焦布隆过滤器(Bloom Filter)这一高效数据结构,结合Go语言实现算法,帮助企业识别和预防泄密风险。通过构建正常操作“指纹库”,实时监测员工操作,快速筛查可疑行为。示例代码展示了如何利用布隆过滤器检测异常操作,并提出优化建议,如调整参数、结合日志分析系统等,全方位筑牢企业信息安全防线,守护核心竞争力。
|
10天前
|
Go C语言
Go语言入门:分支结构
本文介绍了Go语言中的条件语句,包括`if...else`、`if...else if`和`switch`结构,并通过多个练习详细解释了它们的用法。`if...else`用于简单的条件判断;`if...else if`处理多条件分支;`switch`则适用于基于不同值的选择逻辑。特别地,文章还介绍了`fallthrough`关键字,用于优化重复代码。通过实例如判断年龄、奇偶数、公交乘车及成绩等级等,帮助读者更好地理解和应用这些结构。
34 14
|
25天前
|
存储 监控 算法
内网监控系统之 Go 语言布隆过滤器算法深度剖析
在数字化时代,内网监控系统对企业和组织的信息安全至关重要。布隆过滤器(Bloom Filter)作为一种高效的数据结构,能够快速判断元素是否存在于集合中,适用于内网监控中的恶意IP和违规域名筛选。本文介绍其原理、优势及Go语言实现,提升系统性能与响应速度,保障信息安全。
28 5
|
1月前
|
算法 安全 Go
Go语言中的加密和解密是如何实现的?
Go语言通过标准库中的`crypto`包提供丰富的加密和解密功能,包括对称加密(如AES)、非对称加密(如RSA、ECDSA)及散列函数(如SHA256)。`encoding/base64`包则用于Base64编码与解码。开发者可根据需求选择合适的算法和密钥,使用这些包进行加密操作。示例代码展示了如何使用`crypto/aes`包实现对称加密。加密和解密操作涉及敏感数据处理,需格外注意安全性。
46 14
|
1月前
|
存储 安全 Go
Go语言中的map数据结构是如何实现的?
Go 语言中的 `map` 是基于哈希表实现的键值对数据结构,支持快速查找、插入和删除操作。其原理涉及哈希函数、桶(Bucket)、动态扩容和哈希冲突处理等关键机制,平均时间复杂度为 O(1)。为了确保线程安全,Go 提供了 `sync.Map` 类型,通过分段锁实现并发访问的安全性。示例代码展示了如何使用自定义结构体和切片模拟 `map` 功能,以及如何使用 `sync.Map` 进行线程安全的操作。
|
10天前
|
监控 关系型数据库 MySQL
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
19 0
|
2月前
|
开发框架 Go 计算机视觉
纯Go语言开发人脸检测、瞳孔/眼睛定位与面部特征检测插件-助力GoFly快速开发框架
开发纯go插件的原因是因为目前 Go 生态系统中几乎所有现有的人脸检测解决方案都是纯粹绑定到一些 C/C++ 库,如 OpenCV 或 dlib,但通过 cgo 调用 C 程序会引入巨大的延迟,并在性能方面产生显著的权衡。此外,在许多情况下,在各种平台上安装 OpenCV 是很麻烦的。使用纯Go开发的插件不仅在开发时方便,在项目部署和项目维护也能省很多时间精力。
|
3月前
|
Go 数据安全/隐私保护 开发者
Go语言开发
【10月更文挑战第26天】Go语言开发
54 3
|
3月前
|
Java 程序员 Go
Go语言的开发
【10月更文挑战第25天】Go语言的开发
47 3