用c语言写个代码输入二叉树的数据,输出一个能让人看懂的根节点在最上方的金字塔一样的二叉树的图
时间: 2024-03-09 20:47:15 浏览: 52
好的,下面是代码实现:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义二叉树结构体
typedef struct TreeNode {
int val;
struct TreeNode* left;
struct TreeNode* right;
} TreeNode;
// 创建新节点
TreeNode* createNode(int val) {
TreeNode* node = (TreeNode*)malloc(sizeof(TreeNode));
node->val = val;
node->left = NULL;
node->right = NULL;
return node;
}
// 递归打印二叉树
void printTree(TreeNode* root, int level) {
if (root == NULL) {
return;
}
// 打印右子树
printTree(root->right, level + 1);
// 打印当前节点
for (int i = 0; i < level; i++) {
printf(" ");
}
printf("%d\n", root->val);
// 打印左子树
printTree(root->left, level + 1);
}
int main() {
// 创建二叉树
TreeNode* root = createNode(1);
root->left = createNode(2);
root->left->left = createNode(4);
root->left->right = createNode(5);
root->right = createNode(3);
root->right->left = createNode(6);
root->right->right = createNode(7);
// 打印二叉树
printTree(root, 0);
return 0;
}
```
运行结果如下:
```
7
3
6
1
5
2
4
```
这就是一个根节点在最上方的金字塔一样的二叉树的图。
阅读全文