#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 ;
}

最新文章

  1. JavaScript权威设计--JavaScript变量,作用域,声明提前(简要学习笔记四)
  2. Yosemite 快速搭建 自带Apache+PHP5.6+MySQL 开发环境
  3. 2016古装动作喜剧《笨贼别跑》HD720P.国语中字
  4. Android下的数据储存方式
  5. python中xrange和yield的用法
  6. hdu---------(1026)Ignatius and the Princess I(bfs+dfs)
  7. 《Java数据结构与算法》笔记-CH4-4循环队列
  8. cf C. Vasya and Robot
  9. c指针点滴2之比大小
  10. C# 知识点回顾
  11. 数据格式处理(数字,日期),java处理,jsp的fmt处理
  12. mybatis源码跟踪
  13. JS事件流(W3C与IE区别)
  14. Android Multimedia框架总结(十二)CodeC部分之OMXCodec与OMX事件回调流程
  15. linux 编译安装PHP模块
  16. 安装jdk+tomcat
  17. utf8 vs utf8mb4
  18. Zookeeper的下载、安装和启动
  19. 06:vuejs项目实战
  20. ubuntu12下安装eclipse+pydev +1搜索命令+kill指定进程

热门文章

  1. Java 使用stringTemplate导出大批量数据excel(百万级)
  2. [翻译] GiFHUD
  3. 北美IT求职攻略
  4. Sublime Text3 使用总结
  5. Altium制作DC002的PCB封装和3D模型
  6. print(函数.__closure__) 来判断是不是闭包, 返回cell , 是闭包, 返回None 则不是闭包
  7. scrapy爬虫框架之Xpath选择器
  8. 装office系统软件
  9. 「GXOI / GZOI2019」旅行者
  10. [SDOI2017]切树游戏