C语言实现输入一颗二元查找树并将该树转换为它的镜像

2025-05-27 0 70

本文实例讲述了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

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

54

55

56

57

58

59
/*

* Copyright (c) 2011 alexingcool. All Rights Reserved.

*/

#include <iostream>

#include <iterator>

#include <algorithm>

using namespace std;

struct Node {

Node(int i = 0, Node *l = NULL, Node *r = NULL) : item(i), left(l), right(r) {}

int item;

Node *left;

Node *right;

};

Node *Construct()

{

Node *node6 = new Node(11);

Node *node5 = new Node(9);

Node *node4 = new Node(7);

Node *node3 = new Node(5);

Node *node2 = new Node(10, node5, node6);

Node *node1 = new Node(6, node3, node4);

Node *root = new Node(8, node1, node2);

return root;

}

void Convert(Node *root)

{

if(root == NULL)

return;

Convert(root->left);

//在这里试试swap(root->left, root->right),

//看输出结果,有利于理解二叉树递归

Convert(root->right);

swap(root->left, root->right);

}

void InOrder(Node *root)

{

if(root) {

InOrder(root->left);

cout << root->item << " ";

InOrder(root->right);

}

}

void main()

{

Node *root = Construct();

InOrder(root);

cout << endl;

Convert(root);

InOrder(root);

}

希望本文所述实例对大家C程序算法设计的学习有所帮助。

收藏 (0) 打赏

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

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C语言实现输入一颗二元查找树并将该树转换为它的镜像 https://www.kuaiidc.com/75824.html

相关文章

发表评论
暂无评论