在此代码中添加一个二叉树的后序遍历#include<stdio.h> #include<stdlib.h> #include<string.h> #define MAXSIZE 10001 typedef struct { char elem[16]; int length; } SqList; SqList L[MAXSIZE]; int n=0; void LocateElem(SqList s, int n) { int i,j,flag=1,sum,l; for(i=0;i<n;i++) { if(strcmp(L[i].elem,s.elem)==0) { printf("%s is correct\n",s.elem); flag=0; break; } } if(flag) { printf("%s:",s.elem); for(i=0;i<n;i++) { sum=l=0; if(L[i].length==s.length) { for(j=0;j<s.length;j++) { if(L[i].elem[j]!=s.elem[j]) { sum++; } if(sum>1) break; } if(sum<=1) printf(" %s",L[i].elem); } if(L[i].length==s.length+1) { for(j=0;j<s.length;j++,l++) { if(L[i].elem[l]!=s.elem[j]) { j--; sum++; } if(sum>1) break; } if(sum<=1) printf(" %s",L[i].elem); } if(L[i].length==s.length-1) { for(j=0;j<s.length;j++,l++) { if(L[i].elem[l]!=s.elem[j]) { l--; sum++; } if(sum>1) break; } if(sum<=1) printf(" %s",L[i].elem); } } printf("\n"); } } int main() { while(scanf("%s", L[n].elem) != EOF){ if(L[n].elem[0]=='#') break; L[n].length=strlen(L[n].elem); n++; } SqList s; while(scanf("%s", s.elem) != EOF){ if(s.elem[0]=='#') break; s.length=strlen(s.elem); LocateElem(s,n); } return 0; }
时间: 2024-03-19 15:45:30 浏览: 26
这段代码中已经没有二叉树的结构了,所以需要重新添加。在这里,我们可以利用递归的方式实现二叉树的后序遍历。下面是修改后的代码:
```
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAXSIZE 10001
typedef struct {
char elem[16];
int length;
} SqList;
SqList L[MAXSIZE];
int n=0;
void LocateElem(SqList s, int n) {
int i,j,flag=1,sum,l;
for(i=0;i<n;i++) {
if(strcmp(L[i].elem,s.elem)==0) {
printf("%s is correct\n",s.elem);
flag=0;
break;
}
}
if(flag) {
printf("%s:",s.elem);
for(i=0;i<n;i++) {
sum=l=0;
if(L[i].length==s.length) {
for(j=0;j<s.length;j++) {
if(L[i].elem[j]!=s.elem[j]) {
sum++;
}
if(sum>1) break;
}
if(sum<=1) printf(" %s",L[i].elem);
}
if(L[i].length==s.length+1) {
for(j=0;j<s.length;j++,l++) {
if(L[i].elem[l]!=s.elem[j]) {
j--;
sum++;
}
if(sum>1) break;
}
if(sum<=1) printf(" %s",L[i].elem);
}
if(L[i].length==s.length-1) {
for(j=0;j<s.length;j++,l++) {
if(L[i].elem[l]!=s.elem[j]) {
l--;
sum++;
}
if(sum>1) break;
}
if(sum<=1) printf(" %s",L[i].elem);
}
}
printf("\n");
}
}
// 二叉树结构体
typedef struct TreeNode {
char elem[16];
struct TreeNode *left;
struct TreeNode *right;
} TreeNode;
// 后序遍历二叉树
void postOrder(TreeNode *root) {
if (root == NULL) {
return;
}
postOrder(root->left);
postOrder(root->right);
printf("%s ", root->elem);
}
int main() {
while(scanf("%s", L[n].elem) != EOF){
if(L[n].elem[0]=='#') break;
L[n].length=strlen(L[n].elem);
n++;
}
SqList s;
while(scanf("%s", s.elem) != EOF){
if(s.elem[0]=='#') break;
s.length=strlen(s.elem);
LocateElem(s,n);
}
// 生成二叉树
TreeNode *root = (TreeNode *)malloc(sizeof(TreeNode));
root->left = NULL;
root->right = NULL;
strcpy(root->elem, L[0].elem);
for (int i = 1; i < n; i++) {
TreeNode *node = (TreeNode *)malloc(sizeof(TreeNode));
node->left = NULL;
node->right = NULL;
strcpy(node->elem, L[i].elem);
// 将节点插入二叉树
TreeNode *cur = root;
while (cur != NULL) {
if (strcmp(node->elem, cur->elem) < 0) {
if (cur->left == NULL) {
cur->left = node;
break;
} else {
cur = cur->left;
}
} else {
if (cur->right == NULL) {
cur->right = node;
break;
} else {
cur = cur->right;
}
}
}
}
// 后序遍历二叉树
printf("PostOrder: ");
postOrder(root);
printf("\n");
return 0;
}
```
在这段代码中,我们添加了一个二叉树结构体 `TreeNode`,其中包含了节点的元素值 `elem`、左子树指针 `left` 和右子树指针 `right`。我们通过循环读取输入的字符串数组,将每个元素插入到二叉树中。最后,我们调用 `postOrder` 函数来后序遍历二叉树,输出二叉树的后序遍历结果。