c++ 二叉树的遍历
2024-08-23 02:12:30
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <stdarg.h>
#include <time.h>
struct node
{
long data; //存放数据的一个或者多个项
long count;
struct node *pLeft; //左孩子 指向一个二叉树
struct node *pRight; //右孩子 指向一个二叉树
}; struct node * CreateNode(long value)
{
struct node *p=malloc(sizeof(struct node));
p->pLeft=p->pRight=NULL;
p->data=value;
p->count=;
}
struct node * AddNode(struct node * pNode,long v)
{
//情况一 pNode==NULL
if (pNode==NULL)
{
return CreateNode(v);
}
// pNode->data=v
if (pNode->data==v)
{
pNode->count++;
return pNode;
}
//v大于结点数据
if (v>pNode->data)
{
if (pNode->pRight==NULL)
{
pNode->pRight=CreateNode(v);
return pNode->pRight;
}else return AddNode(pNode->pRight,v); //递归调用
}
//v小于 结点数据
if (v<pNode->data)
{
if (pNode->pLeft==NULL)
{
pNode->pLeft=CreateNode(v);
return pNode->pLeft;
}else return AddNode(pNode->pLeft,v); //递归调用
} return NULL;
}
void traversal(struct node* pNode)
{ int i;
if (pNode->pLeft!=NULL)
{
traversal(pNode->pLeft);
}
for (i=;i<=pNode->count;i++)
{
printf("%d,",pNode->data);
}
if (pNode->pRight!=NULL)
{
traversal(pNode->pRight);
} }
int main(void)
{
struct node*root;
long v,i;
printf("请输入二叉树根结点数值:");
scanf("%d",&v);
root=CreateNode(v); //根结点
for (i=;i<=;i++)
{
AddNode(root,i);
}
//遍历
traversal(root);
getchar();
getchar();
getchar();
return ;
}
最新文章
- JavaScript权威设计--JavaScript变量,作用域,声明提前(简要学习笔记四)
- Yosemite 快速搭建 自带Apache+PHP5.6+MySQL 开发环境
- 2016古装动作喜剧《笨贼别跑》HD720P.国语中字
- Android下的数据储存方式
- python中xrange和yield的用法
- hdu---------(1026)Ignatius and the Princess I(bfs+dfs)
- 《Java数据结构与算法》笔记-CH4-4循环队列
- cf C. Vasya and Robot
- c指针点滴2之比大小
- C# 知识点回顾
- 数据格式处理(数字,日期),java处理,jsp的fmt处理
- mybatis源码跟踪
- JS事件流(W3C与IE区别)
- Android Multimedia框架总结(十二)CodeC部分之OMXCodec与OMX事件回调流程
- linux 编译安装PHP模块
- 安装jdk+tomcat
- utf8 vs utf8mb4
- Zookeeper的下载、安装和启动
- 06:vuejs项目实战
- ubuntu12下安装eclipse+pydev +1搜索命令+kill指定进程
热门文章
- Java 使用stringTemplate导出大批量数据excel(百万级)
- [翻译] GiFHUD
- 北美IT求职攻略
- Sublime Text3 使用总结
- Altium制作DC002的PCB封装和3D模型
- print(函数.__closure__) 来判断是不是闭包, 返回cell , 是闭包, 返回None 则不是闭包
- scrapy爬虫框架之Xpath选择器
- 装office系统软件
- 「GXOI / GZOI2019」旅行者
- [SDOI2017]切树游戏