当前位置: 首页 > news >正文

网站域名注册价格seoul什么意思

网站域名注册价格,seoul什么意思,衡水网站推广,页面设计合同二叉排序树 二叉排序树(Binary Sort Tree)或者是一棵空树;或者是具有下列性质的二叉树: (1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值; (2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值; (3)左、右子树也分别为二叉排序树; 基本…

二叉排序树

二叉排序树(Binary Sort Tree)或者是一棵空树;或者是具有下列性质的二叉树:
(1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值;
(2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值;
(3)左、右子树也分别为二叉排序树;

基本步骤

若根结点的关键字值等于查找的关键字,成功。

否则,若小于根结点的关键字值,递归查左子树。

若大于根结点的关键字值,递归查右子树。

若子树为空,查找不成功。

插入算法:

首先执行查找算法,找出被插结点的父亲结点。

判断被插结点是其父亲结点的左、右儿子。将被插结点作为叶子结点插入。

若二叉树为空。则首先单独生成根结点。

注意:新插入的结点总是叶子结点。

void InsertBST(t,key)

//在二叉排序树中插入查找关键字key

{

if(t==NULL){

t=new BiTree;

t->lchild=t->rchild=NULL;

t->data=key;

return; }

if(keydata ) InsertBST(t->lchild,key);

else InsertBST (t->rchild, key );

}

void CreateBiTree(tree,d【 】,n)

//n个数据在数组d中,tree为二叉排序树根

{tree=NULL;

for(i=0;i InsertBST(tree,d);

}

方法一 用递归的方法实现

测试代码

#include <stdio.h>
#include <stdlib.h>#include "bintree.h"void show_menu(void){printf("*******二叉排序树功能测试**********\n");printf("**1. 插入元素 \n");printf("**2. 删除元素 \n");printf("**3. 查找某元素是否在树中 \n");printf("**4. 树是否为空 \n");printf("**5. 树中元素个数 \n");printf("**6. 树的高度 \n");printf("**7. 树的先序遍历 \n");printf("**8. 树的中序遍历 \n");printf("**9. 树的后序遍历 \n");printf("**10.树的层序遍历 \n");printf("**11. 清空树 \n");printf("**0. 退出 \n");printf(">>>>");
}void travel(int n){printf("%d ",n);
}void test_bin_tree(void){BinTree tree = NULL;bin_tree_init(&tree);while(true){show_menu();int opt = 0;int elem = 0;int ret = 0;bool f = true;scanf("%d",&opt);switch(opt){case 1:printf("请输入要插入二叉排序树中的元素:");scanf("%d",&elem);ret = bin_tree_insert(&tree,elem);if(ret == 0){printf("插入成功!\n");}else{if(ret == -1){printf("插入失败!内存问题!\n");}else{printf("树中已有该元素,插入失败!\n");}}break;case 2:printf("请输入要删除的元素:");scanf("%d",&elem);ret = bin_tree_delete(&tree,elem);if(ret == 0){printf("删除成功!\n");}else{printf("删除失败!树中没有该元素!\n");}break;case 3:printf("请输入要查找树中是否存在的元素:");scanf("%d",&elem);if(bin_tree_contain(tree,elem)){printf("树中存在该元素!\n");}else{printf("树中没有该元素!\n");}break;case 4:bin_tree_empty(tree)?puts("空空如也!\n"):puts("树中有元素!\n");case 5:printf("树中元素个数:%u\n",bin_tree_size(tree));case 6:printf("树的高度为:%u\n",bin_tree_hight(tree));break;case 7:bin_tree_front_travel(tree,travel);printf("\n");case 8:bin_tree_mid_travel(tree,travel);printf("\n");case 9:bin_tree_back_travel(tree,travel);printf("\n");case 10:bin_tree_layer_travel(tree,travel);printf("\n");break;case 11:bin_tree_clear(&tree);break;case 0:bin_tree_destroy(&tree);return; }}
}int main(int argc, char *argv[]) {test_bin_tree();return 0;
}

头文件

#ifndef _BIN_TREE_H__
#define _BIN_TREE_H__#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>//二叉(排序)树的结点类型   
typedef struct BNode{int elem;struct BNode *lchild;//struct BNode *lchild,*rchild;struct BNode *rchild;
}BNode,*BinTree;#define BNODESIZE sizeof(struct BNode)//BinTree tree = NULL;   bin_tree_init(&tree);
void bin_tree_init(BinTree* ptree);//struct BNode **proot;  *proot = NULL;
int bin_tree_insert(BinTree* ptree,int elem);
int bin_tree_delete(BinTree *ptree,int elem);
void bin_tree_clear(BinTree *ptree);
void bin_tree_destroy(BinTree *ptree); bool bin_tree_empty(BinTree tree);
size_t bin_tree_size(BinTree tree);
size_t bin_tree_hight(BinTree tree);
//查找 
bool bin_tree_contain(BinTree tree,int elem);void bin_tree_front_travel(BinTree tree,void (*travel)(int));
void bin_tree_mid_travel(BinTree tree,void (*travel)(int));
void bin_tree_back_travel(BinTree tree,void (*travel)(int));
void bin_tree_layer_travel(BinTree tree,void (*travel)(int));#endif //_BIN_TREE_H__

函数实现

http://www.mmbaike.com/news/100538.html

相关文章:

  • 营口电商平台网站建设专业的网页制作公司
  • 搜关键词可以搜到的网站怎么做广州seo招聘信息
  • 颜色选取网站中国站长之家官网
  • 备案用的网站建设方案书刷赞网站推广空间免费
  • 德宏做网站佛山seo优化
  • 网站备案查询 怎么弄关键词排名优化价格
  • 修改网站源码连接数据库怎么做南昌企业网站建设
  • 企业网站的制作周期产品市场调研怎么做
  • 公司门户官网鞍山seo外包
  • 产地证在什么网站做互动营销平台
  • 长春网站免费制作百度开户公司
  • 蒙自网站建设网络推广都有什么方式
  • 企业网站建设 骆诗设计简述网站内容如何优化
  • 淘宝网站链接怎么做要域名访问网站
  • 建设求职网站抖音引流推广免费软件app
  • 穆棱市住房和城乡建设局网站怎么制作网址
  • wordpress动态菜单seo有哪些作用
  • led高端网站建设搜索引擎营销策略有哪些
  • 网站修改报价成品短视频app下载有哪些
  • 招聘公司怎么做网站跨国网站浏览器
  • 做网站建设注册商标是多少类今日新闻摘抄50字
  • 代码运行框wordpress6seo关键词优化排名
  • 北京好的网站设计公司卖友情链接的哪来那么多网站
  • 网站免费制作百度如何推广广告
  • 做网站需要用到技术怎么做seo信息优化
  • 做网站哪家好如何做广告宣传与推广
  • 网站防御怎么做今日国内新闻头条15条
  • 云南网站建设公司排名制作网页的工具软件
  • 做网站基础教程建网站教程
  • 云南凡科建站哪家好最佳磁力吧ciliba磁力链