#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<cstring>
using namespace std;
//头文件
#define VALUE int
//定义数据类型
//-----------------------------------------------
typedef struct BITREE{
 VALUE value;
 int unicode;
 struct BITREE *leftson;
 struct BITREE *rightson;
}BITREE;
//二叉树的定义
//定义根
BITREE root;
//定义树的高度
long high=0;
//定义叶子数
long leaves=0;
//树的队列模型
VALUE treeline[100000];
//二叉树操作
//----------------------------------------------
//创建左子树,返回左子树地址
BITREE* createleftson(BITREE *father,VALUE value){
 BITREE *leftson;
 leftson=(BITREE *)malloc(sizeof(BITREE));
 leftson->value=value;
 father->leftson=leftson;
 leftson->leftson=NULL;
 leftson->rightson=NULL;
 leftson->unicode=father->unicode*2;
 treeline[leftson->unicode]=leftson->value;
 return leftson;
}
//创建右子树,返回右子树地址
BITREE* createrightson(BITREE *father,VALUE value){
 BITREE *rightson;
 rightson=(BITREE *)malloc(sizeof(BITREE));
 rightson->value=value;
 father->rightson=rightson;
 rightson->leftson=NULL;
 rightson->rightson=NULL;
 rightson->unicode=father->unicode*2+1;
 treeline[rightson->unicode]=rightson->value;
 return rightson;
}
//遍历二叉树(为了插节点)
int traversal_node(BITREE *root){
 if(root==NULL)
  return 1;
 if(root->unicode%2==0){
  root->unicode*=2;
  treeline[root->unicode]=root->value;
 }
 else
 {
  root->unicode*=2;
  root->unicode--;
  treeline[root->unicode]=root->value;
 }
 traversal_node(root->leftson);
 traversal_node(root->rightson);
}
//插入左节点,返回左结点地址
BITREE* createleftnode(BITREE *father,VALUE value){
 BITREE *newnode;
 newnode=(BITREE *)malloc(sizeof(BITREE));
 newnode->leftson=father->leftson;
 newnode->rightson=NULL;
 father->leftson=newnode;
 newnode->value=value;
 newnode->unicode=father->unicode*2;
 treeline[newnode->unicode]=newnode->value;
 traversal_node(newnode->leftson);
 return newnode;
}
//插入右结点,返回右结点地址
BITREE* createrightnode(BITREE *father,VALUE value){
 BITREE *newnode;
 newnode=(BITREE *)malloc(sizeof(BITREE));
 newnode->rightson=father->rightson;
 newnode->leftson=NULL;
 father->rightson=newnode;
 newnode->value=value;
 newnode->unicode=father->unicode*2+1;
 treeline[newnode->unicode]=newnode->value;
 traversal_node(newnode->rightson);
 return newnode;
}
//遍历二叉树(先序)
int traversal_first(BITREE *root){
 if(root==NULL)
  return 1;
 //to do
 traversal_first(root->leftson);
 traversal_first(root->rightson);
}
//遍历二叉树(中序)
int traversal_middle(BITREE *root){
 if(root==NULL)
  return 1;
 traversal_middle(root->leftson);
 //to do
 traversal_middle(root->rightson);
}
//遍历二叉树(后序)
int traversal_last(BITREE *root){
 if(root==NULL)
  return 1;
 traversal_last(root->leftson);
 traversal_last(root->rightson);
 //to do
}
//树的高度
int highoftree(BITREE *root){
 int l,r;
 if(root){
  l=highoftree(root->leftson);
  r=highoftree(root->rightson);
  if(l>r)
   return l+1;
  else
   return r+1;
 }
 else
  return 0;
}
/*
 if(root->leftson==NULL&&root->rightson==NULL)
  return 1;
 if(root->leftson==NULL)
  return highoftree(root->rightson)+1;
 if(root->rightson==NULL)
  return highoftree(root->leftson)+1;
 else
  return highoftree(root->leftson)>highoftree(root->rightson)?highoftree(root->leftson):highoftree(root->rightson)+1;
*/
//已知unicode探求树的拓扑路径
int* findpath(int unicode){ 
 int *path;
 path=(int *)malloc(sizeof(int)*1000);
 int k,point=0;
 k=unicode;
 while(k!=1){
  if(k%2==0){
   *(path+point)=2;
   k/=2;
   point++;
  }
  else{
   *(path+point)=1;
   k=(k-1)/2;
   point++;
  }
 }
 *(path+point)=0;
 return path;
}
//注:1代表取左上,2代表取右上

二叉树的实现与一些基本操作(C++环境)的更多相关文章

  1. 【mybatis】1、入门CURD基本操作(环境搭建)

    #1.基本环境 环境 版本 jdk 1.7.0_10 ide eclipse-jee-luna-SR2-win32-x86_64 maven 3.3.3 mybatis 3.2.7 mysql 5.1 ...

  2. MySql(一)mysql服务的基本操作及环境配置

    MySQL服务的启动开始–>计算机–>右键选择管理–>双击打开服务和应用程序–>双击服务–>找到MySQL的服务名称(我的是MySQL56),右键选择启动即可 通过命令行 ...

  3. Docker环境搭建以及基本操作

    Docker环境搭建以及基本操作 Docker环境基本搭建: 基础环境:Centos 7.4        IP:192.168.30.117 [root@docker ~]# cat /etc/re ...

  4. [LeetCode] Invert Binary Tree 翻转二叉树

    Invert a binary tree. 4 / \ 2 7 / \ / \ 1 3 6 9 to 4 / \ 7 2 / \ / \ 9 6 3 1 Trivia: This problem wa ...

  5. 基于Java实现红黑树的基本操作

    首先,在阅读文章之前,我希望读者对二叉树有一定的了解,因为红黑树的本质就是一颗二叉树.所以本篇博客中不在将二叉树的增删查的基本操作了,需要了解的同学可以到我之前写的一篇关于二叉树基本操作的博客:htt ...

  6. JAVA实现二叉树(简易版--实现了二叉树的各种遍历)

    1,个人感觉二叉树的实现主要还是如何构造一颗二叉树.构造二叉树函数的设计方法多种多样,本例采用 addNode 方法实现.以下程序通过定义内部类来表示二叉树的结点,然后再实现了二叉树这种数据结构的一些 ...

  7. java数据结构之二叉树的定义和递归实现

    定义最多有两棵子树的有序树,称为二叉树.二叉树是一种特殊的树.递归定义:二叉树是n(n>=0)个有限结点构成的集合.N=0称为空二叉树:n>0的二叉树由一个根结点和两互不相交的,分别称为左 ...

  8. Conda 配置 Python 环境

    目录 前言 一.Conda 是什么 二.如何获取 三.使用 Conda 命令配置多环境 1.创建新环境 2.激活新环境 3.配置新环境 4.退出新环境 5.检查所有环境 6.检查所有安装的包 7.删除 ...

  9. Java提高篇(二七)-----TreeMap

    TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap的实现,但是为了与Java提高篇系列博文保持一致 ...

随机推荐

  1. 数字图像处理作业使用OpenCV - 使用笔记

    数字图像处理作业的输入图像全部都是灰度图像,所以汇总一下自己遇到的问题答案. OCV的图像容器是Mat<typename>,可以用imread(filename)读取图像,filename ...

  2. [HTML/HTML5]3 页面结构

    在HTML5之前,主要的容器元素是div元素,但在HTML5中提供了数种其它容器元素供我们使用. 因此,当组织Web页面结构时,首先使用HTML将内容分成多部分,然后在对其使用CSS应用样式和格式. ...

  3. node.js的优缺点

    node.js的优缺点 优点: 1. 采用事件驱动,异步编程,为网络服务而设计. 2. node.js非阻塞模式的IO处理给node.js带来在相对较低的资源耗用下的高性能与出众的负载能力. 3. n ...

  4. python3练习-杨辉三角/帕斯卡三角形

    杨辉三角形式如下: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 # 期待输出: # [1] # [1, 1] # [1, 2, 1] # [1, 3, 3, ...

  5. Java集合类学习笔记(Set集合)

    Set集合不允许包含相同的元素,如果试图把两个相同的元素加入同一个Set集合中,则添加操作失败,add()方法返回false,且新元素不会被加入. HashSet类的特点: 不能保证元素的排列顺序,顺 ...

  6. ubtuntu 下安装Erlang R17

    在Ubuntu 下 Erlang R17B 的安装的过程记录: 1 :如果你主机上没有安装jdk,那需先安装,安装过程如下:   #   sudo apt-get update (更新已安装的包)   ...

  7. python网络编程【二】(使用UDP)

    UDP通信几乎不使用文件对象,因为他们往往不能为数据如何发送和接受提供足够的控制.下面是一个基本的UPD客户端: #!/usr/bin/env python import socket,sys hos ...

  8. 高性能javascript(记录一)

    脚本位置:将js脚本放置在body底部,由于脚本会阻塞页面渲染,导致明显延迟,通常表现为空白页面,用户无法游览页面的内容,也无法与页面进行交互.故因此推荐js脚本放在body底部,尽可能减少对整个页面 ...

  9. 深入了解Struts2返回JSON数据的原理

    首先来看一下JSON官方对于"JSON"的解释: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.易于人阅读和编写.同时也易于机器解析 ...

  10. Eclipse - 修改默认user和类的创建日期

    1.找到eclipse.ini文件 2.在文件中找到 -vmargs -Duser.name=xxxxxxxx 3.修改xxxxxxxx为你的名字 4.eclipse中:Window -> Pr ...