javascript如何实现二叉树的创建和遍历?(代码示例)


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章给大家介绍一下使用javascript实现二叉树的创建和遍历的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

1、先说二叉树的遍历,遍历方式:

前序遍历:先遍历根结点,然后左子树,再右子树

中序遍历:先遍历左子树,然后根结点,再右子树

后续遍历:先遍历左子树,然后右子树,再根结点

上代码:主要还是利用递归

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

function TreeCode() {

    let BiTree = function (ele) {

        this.data = ele;

        this.lChild = null;

        this.rChild = null;

    }

 

    this.createTree = function () {

        let biTree = new BiTree('A');

        biTree.lChild = new BiTree('B');

        biTree.rChild = new BiTree('C');

        biTree.lChild.lChild = new BiTree('D');

        biTree.lChild.lChild.lChild = new BiTree('G');

        biTree.lChild.lChild.rChild = new BiTree('H');

        biTree.rChild.lChild = new BiTree('E');

        biTree.rChild.rChild = new BiTree('F');

        biTree.rChild.lChild.rChild = new BiTree('I');

        return biTree;

    }

}

 

//前序遍历

function ProOrderTraverse(biTree) {

    if (biTree == null) return;

    console.log(biTree.data);

    ProOrderTraverse(biTree.lChild);

    ProOrderTraverse(biTree.rChild);

}

 

//中序遍历

function InOrderTraverse(biTree) {

    if (biTree == null) return;

    InOrderTraverse(biTree.lChild);

    console.log(biTree.data);

    InOrderTraverse(biTree.rChild);

}

 

//后续遍历

function PostOrderTraverse(biTree) {

    if (biTree == null) return;

    PostOrderTraverse(biTree.lChild);

    PostOrderTraverse(biTree.rChild);

    console.log(biTree.data);

}

 

let myTree = new TreeCode();

console.log(myTree.createTree());

console.log('前序遍历')

ProOrderTraverse(myTree.createTree());

console.log('中序遍历')

InOrderTraverse(myTree.createTree());

console.log('后续遍历')

PostOrderTraverse(myTree.createTree());

二叉树的非递归遍历

  • 深度优先遍历(主要利用栈的先进后出)

  • 广度优先遍历(主要利用队列的先进先出)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

//深度优先非递归

function DepthFirstSearch(biTree) {

    let stack = [];

    stack.push(biTree);

 

    while (stack.length != 0) {

        let node = stack.pop();

        console.log(node.data);

        if (node.rChild) {

            stack.push(node.rChild);

        }

        if (node.lChild) {

            stack.push(node.lChild);

        }

 

    }

 

}

 

 

//广度优先非递归

function BreadthFirstSearch(biTree) {

    let queue = [];

    queue.push(biTree);

    while (queue.length != 0) {

        let node = queue.shift();

        console.log(node.data);

        if (node.lChild) {

            queue.push(node.lChild);

        }

        if (node.rChild) {

            queue.push(node.rChild);

        }

    }

 

}

深度优先主要是利用栈,先压右子树,再压左子树

广度优先主要利用队列,先入左子树,再入右子树

深度优先的遍历结果与前序遍历相同ABDGHCEIF,广度优先的遍历结果是 ABCDEFGHI

2、创建二叉树

1中创建二叉树的方式过于笨拙,假入我们根据完全二叉树的模型建立自己的二叉树,空数据的地方用#表示,如下图所示我们称之为扩展二叉树,我们取其前序遍历的序列 AB#D##C##。

上代码:也是利用递归

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

//前序遍历得到的字符串

let strArr = 'AB#D##C##'.split('');

 

function BiTree(ele) {

    this.data = ele;

    this.lChild = null;

    this.rChild = null;

}

var newTree = new BiTree('#');

 

function createBiTree(biTree) {

    if (strArr.length == 0) return;

    let str = strArr.shift();

    if (str == '#') return;

    biTree.data = str;

    if (strArr[0] != '#') {

        biTree.lChild = new BiTree('#')

    }

    createBiTree(biTree.lChild);

    if (strArr[0] != '#') {

        biTree.rChild = new BiTree('#')

    }

    createBiTree(biTree.rChild);

}

createBiTree(newTree);

console.log(newTree);

ProOrderTraverse(newTree)

你也可以用中序遍历或者后序遍历实现二叉树的创建,代码里生成结点和构建左右子树的代码顺序交换一下就行了

推荐教程:《JavaScript视频教程》

以上就是javascript如何实现二叉树的创建和遍历?(代码示例)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

canvas实现九宫格心形拼图的方法(附代码)

javascript如何实现json字符串与对象转换

javascript字符串转换函数是什么

快速入门createjs实例教程

分享12个提升程序员软技能与效率的开发工具

聊聊javascript里的sleep()方法

javascript如何给元素添加自定义属性

javascript怎么清除cookie

javascript中table怎么删除行

javascript专题之五:深浅拷贝

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...