数据结构与算法-二叉树相关上机实验
#include<stdio.h> #include<malloc.h> #define OK 1 #define ERROR 0 #define MAXNUM 20 typedef int Status; typedef struct bnode { int data; struct bnode *lchild,*rchild; }bnode_type,*blink; typedef struct Stack { blink data[MAXNUM]; int top; }Stack; Status create(blink &root); void preorder_1(blink root); void inorder_1(blink root); void postorder_1(blink root); void preorder_2(blink root); void inorder_2(blink root); void postorder_2(blink root); void create_stack(Stack &S); Status empty(Stack S); void push(Stack &S, blink BTN); blink pop(Stack &S); int treelen(blink tree); int leaves(blink tree); int nodes(blink root); int main() { blink mytree; create(mytree); printf("\npreorder:\n"); preorder_1(mytree); printf("\ninorder:\n"); inorder_1(mytree); printf("\npostorder:\n"); postorder_1(mytree); printf("\n----------------\n"); printf("\npreorder:\n"); preorder_2(mytree); printf("\ninorder:\n"); inorder_2(mytree); printf("\npostorder:\n"); postorder_2(mytree); printf("\n----------------\n"); printf("the depth of this tree is: %d",treelen(mytree)); printf("\nthere are %d leaves in this tree",leaves(mytree)); printf("\nthere are %d nodes in this tree",nodes(mytree)); } Status create(blink &root) { blink p,q; int k; int i,n; root=NULL; printf("input n:"); scanf("%d",&n); if(n<=0) { printf("invalid input"); return ERROR; } for(i=0;i<n;i++) { p=(blink)malloc(sizeof(bnode_type)); p->lchild=NULL; p->rchild=NULL; printf("input k:"); scanf("%d",&k); p->data=k; if(root==NULL) root=p; else { q=root; while(q!=NULL) { if(q->data>k) { if(q->lchild!=NULL) q=q->lchild; else { q->lchild=p; q=NULL; } } else { if(q->rchild!=NULL) q=q->rchild; else { q->rchild=p; q=NULL; } } } } } return OK; } void preorder_1(blink root) { printf("%d ",root->data); if(root->lchild!=NULL) preorder_1(root->lchild); if(root->rchild!=NULL) preorder_1(root->rchild); } void inorder_1(blink root) { if(root->lchild!=NULL) inorder_1(root->lchild); printf("%d ",root->data); if(root->rchild!=NULL) inorder_1(root->rchild); } void postorder_1(blink root) { if(root->lchild!=NULL) postorder_1(root->lchild); if(root->rchild!=NULL) postorder_1(root->rchild); printf("%d ",root->data); } void create_stack(Stack &S) { S.top=0; } Status empty(Stack S) { if(S.top==0) return OK; else return ERROR; } void push(Stack &S, blink BTN) { S.data[S.top]=BTN; S.top++; } blink pop(Stack &S) { S.top--; return(S.data[S.top]); } void preorder_2(blink root) { blink p; Stack sta; create_stack(sta); p=root; while(p!=NULL||!empty(sta)) { if(p!=NULL) { printf("%d ",p->data); push(sta,p); p=p->lchild; } else { p=pop(sta); p=p->rchild; } } } void inorder_2(blink root) { blink p; Stack sta; create_stack(sta); p=root; while(p!=NULL||!empty(sta)) { if(p!=NULL) { push(sta,p); p=p->lchild; } else { p=pop(sta); printf("%d ",p->data); p=p->rchild; } } } void postorder_2(blink root) { blink p; Stack sta1,sta2; create_stack(sta1); create_stack(sta2); if(root!=NULL) { push(sta1,root); } while(!empty(sta1)) { p=pop(sta1); push(sta2,p); if(p->lchild!=NULL) { push(sta1,p->lchild); } if(p->rchild!=NULL) { push(sta1,p->rchild); } } while(!empty(sta2)) { p=pop(sta2); printf("%d ",p->data); } } int leaves(blink root) { int n=0; blink p; Stack sta; create_stack(sta); p=root; while(p!=NULL||!empty(sta)) { if(p!=NULL) { if(p->lchild==NULL && p->rchild==NULL) { n++; } push(sta,p); p=p->lchild; } else { p=pop(sta); p=p->rchild; } } return n; } int treelen(blink root) { blink p=root; int n=0,l=0,r=0; if(p==NULL) { return 0; } if(p->lchild) { l=treelen(p->lchild); } if(p->rchild) { r=treelen(p->rchild); } n=(l>r)?l:r; return (n+1); } int nodes(blink root) { int n=0; blink p; Stack sta; create_stack(sta); p=root; while(p!=NULL||!empty(sta)) { if(p!=NULL) { n++; push(sta,p); p=p->lchild; } else { p=pop(sta); p=p->rchild; } } return n; }
非递归的后序遍历用了两个栈 应该还有其他的方法
void postorder_3(blink root) { blink p,pre;//pre用来保存访问过的结点 pre=NULL; Stack sta; create_stack(sta); p=root; while(p!=NULL||!empty(sta)) { if(p!=NULL) { push(sta,p); p=p->lchild; } else { p=pop(sta); if(p->rchildNULL)//p没有右孩子 { pre=p; printf("%d ",p->data); p=NULL; } else if(p->rchildpre)//p有右孩子 但是已经访问过了 { pre=p; printf("%d ",p->data); p=NULL; } else { push(sta,p); p=p->rchild; } } } }
Work Hard
But do not forget to enjoy life😀
本文来自博客园,作者:YuhangLiuCE,转载请注明原文链接:https://www.cnblogs.com/YuhangLiuCE/p/16866717.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)