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

织梦网站转跳手机站网站建设网站需要什么软件

织梦网站转跳手机站,网站建设网站需要什么软件,制作网页排版 怎么将导航放下面,哪个网站做新加坡劳务比较好的二叉排序树 二叉排序树(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.yayakq.cn/news/918256/

相关文章:

  • 网站建设制度微信小程序设计
  • 数据上传网站策划案
  • 网站建设-英九网络响应式布局网站建设
  • 建设部网站规范下载咋做网站代码背景图
  • 企业手机网站源码下载2015做导航网站有哪些功能
  • 南京汽车企业网站建设外贸免费自助建站平台
  • 在英特尔上建设网站可选择的方案有网易那个自己做游戏的网站是什么原因
  • 南联网站建设推广合肥网站定制开发公司
  • 器材管理网站开发福田网站建设推广
  • 怎么登陆建设银行网站看开户行校园推广策略
  • 网站推广服务合同模板wordpress用不了了
  • 学校 网站建设招聘怎么制作属于自己的网站
  • 网站专题策划网站推广的渠道有
  • 网站开发进度控制计划表网站建设公司的发展规划
  • 北京优化词网站小程序发布流程在哪里
  • 西安网站优化维护三元里网站建设
  • 怎么保证网站安全性建筑人才网官方网站入口
  • 如何编程制作自己的网站十大垂直电商平台
  • 互联网电商网站建设电商网站系统
  • wordpress全站cdn ssl网站成本费用
  • 个性化网站制作单页网站建设
  • 聊城做网站的公司策划网站改版建设
  • 建设银行昆山分行网站电商资源网站
  • 网站建设响应式汕尾旅游攻略app跳转网站
  • 做网站购买模板微信公众平台开发源代码
  • 个人如何建设网站网站 运营
  • 一个网站建设都需要什么做网投网站好
  • 电脑禁止访问网站设置腾讯企业邮箱手机登录入口
  • 专业零基础网站建设教学培训响应式个人网站psd
  • 大连网站建设ewaylife工程建设管理网站