复制代码 代码如下:
// 二叉树.cpp : 定义控制台应用程序的入口点。
//
/*
*二叉树作业
*2012.12.1 13:55
*Made By Karld Vorn Doenitz
*/
#include "stdafx.h"
#include<iostream>
#include<string>
using namespace std;
class TreeNode{//建立节点类
public:
char num;
TreeNode *leftchild,*rightchild;
};
class Queue{//建立队列类
public:
int front,rear;
TreeNode *elem;
};
void cmd();
void initQueue(Queue *q);
bool isEmpty(Queue *q);
void enQueue(Queue *q,TreeNode *e);
void outQueue(Queue *q,TreeNode *e);
void createBiTree(TreeNode * &T);
TreeNode* PreFind(TreeNode *T,char da);
void order(TreeNode *T);
void midOrder(TreeNode * T);
void addChild(TreeNode *T,char clue,char add,string side);
void deleteNode(TreeNode *T,char delchar);
int main(){//主函数
cmd();
return 0;
}
void cmd(){//命令函数
/*
*以下为命令行指令
*共有六种命令
*/
char commands;
TreeNode *T=NULL;
cout<<"*"<<"___________命令如下_______________"<<endl;
cout<<"*"<<"1、按下c键先序创建二叉树; "<<"*"<<endl;
cout<<"*"<<"2、按下m键中序递归遍历二叉树; "<<"*"<<endl;
cout<<"*"<<"3、按下o键层次遍历二叉树; "<<"*"<<endl;
cout<<"*"<<"4、按下s键给定元素查找节点; "<<"*"<<endl;
cout<<"*"<<"5、按下i键指定位置插入节点; "<<"*"<<endl;
cout<<"*"<<"6、按下d键删除指定的节点; "<<"*"<<endl;
cout<<"*"<<"请输入你的选择: "<<"*"<<endl;
cout<<"*"<<"__________________________________"<<endl;
cin>>commands;
while(commands){
/*
*采用switch语句
*while循环
*/
switch (commands){
case 'c':
{
cout<<"输入要创建的二叉树,以#为空节点。"<<endl;
createBiTree(T);
}break;
case 'm':
{ if(T==NULL)cout<<"此二叉树为空,请先创建二叉树!!!"<<endl;
else{
cout<<"中序遍历二叉树的结果为:";
midOrder(T);
cout<<endl;}
}break;
case 'o':{
if(T==NULL)cout<<"此二叉树为空,请先创建二叉树!!!"<<endl;
else{cout<<"层次遍历二叉树的结果为:";
order(T);
cout<<endl;
} }break;
case 's':{char ch;
cout<<"输入要查找的元素:"<<endl;
cin>>ch;
cout<<"要找的节点的左孩子是:";
TreeNode *bt=PreFind(T,ch);
if(bt->leftchild!=NULL)
cout<<bt->leftchild->num<<endl;
else cout<<"此节点是叶子,无左孩子!!!"<<endl;
cout<<"要找的节点的右孩子是:";
if(bt->rightchild!=NULL)
cout<<bt->rightchild->num<<endl;
else cout<<"此节点是叶子,无右孩子!!!"<<endl;
}break;
case 'i':{char clue,add;
string side;
cout<<"输入插入位置:";
cin>>clue;
cout<<"输入插入的元素:";
cin>>add;
cout<<"选择要插入的是左子树(请输入left)还是右子树(请输入right)";
cin>>side;
addChild(T,clue,add,side);
}break;
case 'd':{
char del;
cout<<"输入要删除的节点的元素值:"<<endl;
cin>>del;
deleteNode(T,del);
}break;
default:cout<<"输入选择非法";break;
}
cout<<"输入你的选择:"<<endl;
cin>>commands;
}
}
void initQueue(Queue *q){//初始化队列
q->elem=new TreeNode;
q->front=q->rear=0;
}
bool isEmpty(Queue *q){//检查队列是否为空
if(q->front==q->rear)
return true;//队为空
else return false;//队不为空
}
void enQueue(Queue *q,TreeNode *e){//入队
q->elem[q->rear]=*e;
q->rear++;
}
void outQueue(Queue *q,TreeNode *e){//出队
if(q->front==q->rear)return;
*e=q->elem[q->front];
q->front++;
}
void createBiTree(TreeNode * &T){//创建二叉树
char ch;
cin>>ch;
if(ch=='#') T=NULL;
else {//采用递归先序创建二叉树
T=new TreeNode;
T->num=ch;
createBiTree(T->leftchild);
createBiTree(T->rightchild);
}
}
TreeNode* PreFind(TreeNode *T,char da){//给定元素值查找结点指针位置并返回其指针,此方法采用的先序遍历
TreeNode *temp;
TreeNode *tree[20];
int top=0;
while(T!=NULL||top!=0){
while(T!=NULL){
if(T->num==da)
temp=T;
top++;
tree[top]=T;
T=T->leftchild;
}
if(top!=0){
T=tree[top]->rightchild;
top--;
}
}
return temp;
}
void order(TreeNode *T){//层序遍历二叉树
Queue *q=new Queue;
TreeNode *p=new TreeNode;
if(T!=NULL) {
initQueue(q);
enQueue(q,T);
while(!isEmpty(q)){//将根节点的左右两个子节点推入队内
outQueue(q,p);
cout<<p->num<<" ";
if(p->leftchild!=NULL)
enQueue(q,p->leftchild);
if(p->rightchild!=NULL)
enQueue(q,p->rightchild);
}
}else
cout<<"此二叉树为空!!!";
}
void midOrder(TreeNode * T){//二叉树中序递归遍历
if(T!=NULL){
midOrder(T->leftchild);//中序遍历T的左子树
cout<<T->num<<" "; //访问根节点
midOrder(T->rightchild);//中序遍历T的右子树
}
}
void addChild(TreeNode *T,char clue,char add,string side){//插入左右孩子操作,根据clue查找节点,由side决定插入左孩子还是右孩子
TreeNode *&late=new TreeNode;
late->num=add;
late->leftchild=NULL;
late->rightchild=NULL;
TreeNode *original=PreFind(T,clue);//查找指定的节点
if(side=="left"){
if(original->leftchild==NULL){//根结点的左孩子结点为空
original->leftchild=late;
}
}else{
if(original->rightchild==NULL){//根结点的右孩子结点为空
original->rightchild=late;
}
}
}
void deleteNode(TreeNode *T,char delchar){ //删除节点及其子节点
if (T!=NULL){//如果根节点不为空
if (T->num==delchar){//如果根节点为要删除的节点
delete T->leftchild;//删除左孩子节点
T->leftchild=NULL;//左指针指向NULL
delete T->rightchild;//删除右孩子节点
T->rightchild=NULL;//右指针指向NULL
delete T;//删除节点T
}else if (T->leftchild!=NULL&&T->leftchild->num==delchar){//如果左孩子为要删除的节点
delete T->leftchild->leftchild;//先删除左孩子的左孩子
delete T->leftchild->rightchild;//再删除左孩子的右孩子
delete T->leftchild;//最后删除左孩子
T->leftchild=NULL;//左指针为空
}else if (T->rightchild!=NULL&&T->rightchild->num==delchar){//如果右孩子为要删除的节点
delete T->rightchild->leftchild;//先删除右孩子的左孩子
delete T->rightchild->rightchild;//再删除右孩子的右孩子
delete T->rightchild;//最后删除右孩子
T->rightchild=NULL;//右指针为空
}else {
if(T->leftchild!=NULL){ //如果左孩子不为空
deleteNode(T->leftchild,delchar);//删除左孩子结点
}if(T->rightchild!=NULL){ //如果右孩子不为空
deleteNode(T->rightchild,delchar);//删除右孩子节点
}
}
}
}
相关推荐:
什么是亚马逊seo策略,亚马逊的seo推广是什么 ,天天学术ai写作优惠券
未来智能:AI智能人工软件引领数字化变革
未来的效率利器AI软件下载AI,助您轻松驾驭智能世界
《权重参谋:让您的网站轻松登顶搜索引擎的秘密武器》,设计微信社群私域营销推广简案
ChatGPT当前不可用?如何应对AI服务中断的挑战,ai文章免费写作app
SEO优化排名原理解析:如何提高网站排名,实现精准流量获取,奥迪ai售价
SEO站群:打造强大网络营销引擎,助力企业快速提升排名与流量,seo网站排名案例
什么是seo技术,什么是seo及seo的作用 ,AI倒放仓鼠
seo高手有什么条件,seo难上手吗 ,指南ai写作电力创新
ChatGPT页面打不开怎么办?这些解决方法让你轻松访问AI助手!,分散ai
SEO表格:优化网站排名的秘密武器,大数据推广营销费用多少
SEO做好,企业网站流量翻倍的关键,seo白帽技术有哪些
SEO化学物质:如何在化工行业提升搜索引擎排名和品牌曝光,rack ai
SEO新闻:2025年最新趋势与最佳实践,你不可错过的SEO战略,郑州网络营销推广的优势
ChatGPT中显示已进行一处编辑,但看不到内容?你需要了解的隐藏问题!,ai敲
AI网站开发与代码创新:引领未来数字化变革的关键,ai ay规则
seo要寻找什么资源,怎么找seo ,ai插画描边
AI提供的阅读书目对学生的专业知识有多大帮助,沃奇ai
seo深度优化插件是什么,深度优化手机软件 ,ai的缩写
SEO通过-如何通过SEO优化让你的业务在搜索引擎中脱颖而出,保定网站建设推广专家
优化投入,让企业更具竞争力,怎样推广营销方案
什么是seo网站推广,什么是seo网站推广 ,ai酷男人
京东业绩再创新高:未来电商巨头的成功之道,如何做seo优化留痕
SEO范例:如何通过优化提升网站流量,获取更多商机,广州抖音seo搜索广告
SEO可以帮助网站在搜索引擎中获得较高的排名-助力企业数字化转型的关键,赵立新AI换脸图片对比
SEO与网络推广机构:如何选择最适合你的数字营销合作伙伴,ai写作软件性价比高吗
SEO已经成为数字营销的核心,如何利用SEO提升网站流量和转化率,含山网站优化推广
AI代谢文章:从灵感到成果的创作革命
seo营销到底是什么,seo算什么营销 ,ai里面新建
SEO添加:提升网站流量与排名的必备策略,seo团队成员中国人
SEO广告:如何借助SEO提升品牌曝光与销售业绩?,网站推广怎么选择
SEO更好,让你的网站从此脱颖而出,渝中的知名网站建设
如何用AI写公众号文章?让创作更高效、更轻松
实用AI工具:提升效率、优化生活的科技利器
用AI征文工具,轻松创作出精彩文章!
OpenAI无法验证支付方式?解决方案与常见问题解析,你好月光ai
ChatGPT您的应用遇到问题,无法正常启动?如何解决并重新体验智能助手的魅力!,男头ai关键词
ChatGPT无法加载?检查您的网络设置并尝试重启ChatGPT,助您畅享无障碍智能对话体验,ai记录人
ChatGPT网页版内容显示不全的原因与解决方案,ai超级绘
ChatGPT国内版:为中国用户量身定制的智能助手,开启AI新纪元,ai文章赚钱
用AI优化文章,轻松提升内容质量与创作效率
Zkept:重塑未来生活的智能科技革新,营销推广的面试问题
ChapGPT免费爬墙,轻松访问全球互联网资源!,蜜桃ai插画
ChatGPT网站突然不能用了?如何快速解决这个问题,让你重新畅享AI对话!,ai新建多个画板
seo竞价做的什么工作,seo 竞价 ,office智能ai
seo词库优化,搜索词条优化 ,ai点选择
Chat免费,让沟通无界限,尽享智能对话时代,ai没办法置顶
中国AI软实力崛起:技术创新与产业应用的完美融合,seo0066
AI网页设计生成-智能化创造无限可能,ai机甲风背景音乐
SEO快速排名实例:如何通过实战技巧提升网站排名,快速突破流量瓶颈,安徽ai跑步机企业