酷代码 AI
菜单
全部AI  /  热门  /  AI写代码神器
服务商

1—create tree; 2—inorder; 3—postorder; 4—high; 5—ancent; 6—clear tree; 7—exit. 输入“1”后,提示输入二叉树的扩充先序序列,“空”可以使用一个特殊字符代表,用输入的序列构造好二叉树。 输入“2”后,对前面构造好的二叉树进行中序遍历,打印出二叉树的中序序列。 输入“3”后,对前面构造好的二叉树进行后序遍历,打印出二叉树的后序序列。 输入“4”后,对前面构造好的二叉树进行某种遍历操作,计算出各结点的高度,并打印出各结点的高度。 输入“5”后,提示输入某结点的名字,对前面构造好的二叉树进行某种遍历操作,找出输入结点的所有祖先,并将该结点祖先打印出来。 输入“6”后,将二叉树各结点的内存释放,变成一棵空树。 输入“7”后,退出程序。 对于“1~6”的操作,执行完后,要返回主程序,打印出主提示,以便进行下一步操作。用c语言

```c #include <stdio.h> #include <stdlib.h> // 二叉树的节点结构体 typedef struct TreeNode { char data; struct TreeNode *left; struct TreeNode *right; } TreeNode; // 创建新节点 TreeNode* createNode(char data) { TreeNode* newNode = (TreeNode*)malloc(sizeof(TreeNode)); newNode->data = data; newNode->left = NULL; newNode->right = NULL; return newNode; } // 根据扩充先序序列构建二叉树 TreeNode* buildTree(char* preorder, int* index) { char data = preorder[*index]; (*index)++; if (data == '#') { return NULL; } TreeNode* root = createNode(data); root->left = buildTree(preorder, index); root->right = buildTree(preorder, index); return root; } // 中序遍历 void inorderTraversal(TreeNode* root) { if (root!= NULL) { inorderTraversal(root->left); printf("%c ", root->data); inorderTraversal(root->right); } } // 后序遍历 void postorderTraversal(TreeNode* root) { if (root!= NULL) { postorderTraversal(root->left); postorderTraversal(root->right); printf("%c ", root->data); } } // 计算节点高度 int height(TreeNode* root) { if (root == NULL) { return 0; } int leftHeight = height(root->left); int rightHeight = height(root->right); return (leftHeight > rightHeight? leftHeight : rightHeight) + 1; } // 打印节点高度 void printHeights(TreeNode* root) { if (root!= NULL) { int h = height(root); printf("%c 的高度为: %d\n", root->data, h); printHeights(root->left); printHeights(root->right); } } // 查找节点的祖先 void findAncestors(TreeNode* root, char target, TreeNode* ancestors[]) { if (root == NULL) { return; } if (root->data == target) { int i = 0; while (ancestors[i]!= NULL) { printf("%c ", ancestors[i]->data); i++; } return; } ancestors[0] = root; findAncestors(root->left, target, ancestors + 1); findAncestors(root->right, target, ancestors + 1); } // 释放二叉树内存 void clearTree(TreeNode* root) { if (root!= NULL) { clearTree(root->left); clearTree(root->right); free(root); } } int main() { TreeNode* root = NULL; int choice; char preorder[100]; int index = 0; do { printf("1—create tree\n2—inorder\n3—postorder\n4—high\n5—ancent\n6—clear tree\n7—exit\n"); scanf("%d", &choice); switch (choice) { case 1: printf("请输入二叉树的扩充先序序列: "); scanf("%s", preorder); root = buildTree(preorder, &index); break; case 2: printf("中序序列: "); inorderTraversal(root); printf("\n"); break; case 3: printf("后序序列: "); postorderTraversal(root); printf("\n"); break; case 4: printf("各节点高度: \n"); printHeights(root); printf("\n"); break; case 5: printf("请输入要查找祖先的节点: "); char target; scanf(" %c", &target); TreeNode* ancestors[100] = {NULL}; findAncestors(root, target, ancestors); printf("\n"); break; case 6: clearTree(root); root = NULL; break; } } while (choice!= 7); return 0; } ``` 1. 输入的扩充先序序列格式要正确,特殊字符代表空节点要统一。 2. 释放内存时要确保递归释放所有节点,避免内存泄漏。 3. 处理用户输入时要进行适当的错误检查和处理。 [2024-12-21 16:32:51 | AI写代码神器 | 1114点数解答]

相关提问