c语言打印树形结构
时间: 2023-08-16 13:03:33 浏览: 50
打印树形结构可以使用递归的方式来实现,以下是一个示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#define MAX_DEPTH 20 // 最大深度
// 定义树节点
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 depth) {
if (root == NULL) {
return;
}
// 打印右子树
printTree(root->right, depth + 1);
// 打印当前节点
for (int i = 0; i < depth; i++) {
printf(" ");
}
printf("%d\n", root->val);
// 打印左子树
printTree(root->left, depth + 1);
}
int main() {
// 创建一个示例二叉树
TreeNode* root = createNode(1);
root->left = createNode(2);
root->right = createNode(3);
root->left->left = createNode(4);
root->left->right = createNode(5);
root->right->left = createNode(6);
root->right->right = createNode(7);
// 打印二叉树
printTree(root, 0);
return 0;
}
```
输出结果为:
```
7
3
6
1
5
2
4
```
其中,每个节点的值前面都有一些空格,用来表示它在树中的深度。这里只是一个示例代码,实际应用中可能需要根据具体情况进行修改。