二叉树遍历

<template>
  <div>{{ data }}</div>
</template>

<script setup lang="ts">
import { ref } from "vue";
const data = ref<any>([]);
const tree: any = {
  value: 1,
  left: {
    value: 7,
    left: {
      value: 3,
    },
    right: {
      value: 5,
      left: {
        value: 9,
      },
    },
  },
  right: {
    value: 3,
    right: {
      value: 8,
    },
  },
};
//先序优先查找  使用递归查找
const findTree = (tree: any, result: any = []) => {
  if (tree) {
    result.push(tree.value);
    findTree(tree.left, result);
    findTree(tree.right, result);
  }
  return result;
};
// data.value=findTree(tree, []);

//广度优先查找  使用while将二叉树的每一项推入栈中,然后使用shift将栈中的元素取出来
const findTree2 = (tree: any, result: any = []) => {
  if (tree) {
    const queue = [tree];
    while (queue.length) {
      const item = queue.shift();//取出第一个并把第一个删除
      result.push(item.value);
      if (item.left) queue.push(item.left);
      if (item.right) queue.push(item.right);
    }
  }
  return result;
};
data.value = findTree2(tree, []);
</script>

<style scoped></style>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容