当Kotlin遇见数据结构丨实现顺序存储的二叉树并遍历

本文介绍了如何在Kotlin中创建和遍历顺序存储的二叉树。首先,通过新建数据类ArrayBianryTree来定义顺序存储的二叉树节点,并在Activity中创建和赋值树对象。接着,详细讲解了如何在Bean中实现前序遍历方法,并在Activity中调用此方法更新UI,展示了Kotlin中利用data class简化代码的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本例中树结构、节点权如下图所示

  • 顺序存储是指将二叉树存储在一个数组中,通过存储元素的下标反映元素之间的父子关系。任何一个二叉树都可以转换为数组,同理,任何一个数组都可以转换为二叉树。
  • 顺序存储的二叉树通常只考虑完全二叉树(满二叉树其实也是一个完全二叉树)
  • 第N个元素的左子节点为:2*N+1
  • 第N个元素的右子节点为:2*N+1
  • 第N个元素的父节点为:(N-1)/ 2(整数相除得整数)

1. Kotlin 中顺序存储的二叉树如何创建

1.1 新建顺序存储的二叉树 Bean:ArrayBianryTree.kt

/**
 * @des 顺序存储二叉树Bean
 * @author liyongli 20190220
 *
 * @param data 准备遍历的数组,不可为null
 * */
data class ArrayBianryTree(var data
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MobMsg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值