排序二叉树构建二叉排序树,依次输入56,78,34,45,85,45,36,91,84,78,两个45和78

排序二叉树  时间:2021-09-12  阅读:()

构造一个二叉排序树

看了百度知道之前有人回答 “二叉排序树的插入 如果遇到 相同的节点 怎么办”,你也可以看一下该问题的答案,个人觉得挺有道理的。

根据这个结论,该二叉树这样排 12 / 5 17 / / 3 5 14 20 9 15 / 8 10 或者 12 / 5 17 / / 3 9 14 20 / 5 8 10 15 都可以,看你的要求,只要中序遍历是递增即可。

上述两个中序遍历都是 3 5 5 8 9 10 12 14 15 17 20

最佳排序二叉树在结构上的特点是什么

展开全部 堆排序就是相当于一个排序二叉树,只是它是根节点的优先级别大于任何儿子的优先级别,这样可以每次删除根节点,然后调整整个堆。

program heap; var a:array[1..10000] of integer; n,i:integer; procedure down(i:integer); var x,j:integer; begin x:=a[i]; j:=i*2; while j<=n do begin if a[j]>a[j+1] then j:=j+1; if a[j]begin a[i]:=a[j]; i:=j; j:=i*2; end else break; end; a[i]:=x; end; procedure delete(i); begin n:=n-1; if (n=0)or(i=n+1) then exit else begin a[i]:=a[n+1]; down(i); end; end; begin readln(n); for i:=1 to n do read(a[i]); for i:=n div 2 downto 1 do down(i); for i:=1 to n do begin write(a[1]); delete(1); end; end. 如果对您有帮助,请记得采纳为满意答案,谢谢!祝您生活愉快! vaela

用C语言实现二叉排序树

#include<stdlib.h> #include<stdio.h> int counter; /*计数器*/ struct tree /*声明书的结构*/ {struct tree *left; int data; struct tree *right; }; typedef struct tree treenode; /*声明新类型树的结构*/ typedef treenode *b_tree; /*声明二叉树的链表*/ b_tree insert_node(b_tree root,int node) /*插入二叉树的结点*/ {b_tree newnode; b_tree currentnode; b_tree parentnode; newnode=(b_tree)malloc(sizeof(treenode)); /*分配新结点空间*/ newnode->data=node; newnode->right=NULL; newnode->left=NULL; if(root==NULL)return newnode; else{currentnode=root; while(currentnode!=NULL) {parentnode=currentnode; if(currentnode->data>node) currentnode=currentnode->left; else currentnode=currentnode->right; } if(parentnode->data>node) parentnode->left=newnode; else parentnode->right=newnode; } return root; /*返回根结点的指针*/ } b_tree create_btree(int *data, int len) /*建立二叉树*/ { b_tree root=NULL; int i; for(i=0;i<len;i++) root=insert_node(root,data[i]); return root; } void inorder(b_tree point) { /*中序遍历二叉树*/ if(point!=NULL) {inorder(point->left); printf(" %d ",point->data); /*处理结点内容*/ inorder(point->right); } } int tree_search(b_tree root,int key) /*查找二叉树*/ { b_tree pointer; pointer=root; counter=0; while(pointer!=NULL) { counter++; if(pointer->data<key) pointer=pointer->right; else if(pointer->data>key) pointer=pointer->left; else if(pointer->data==key) return 1; } return 0; } void main() { b_tree root=NULL; int m,i,index; /*读入输入值所用的暂存变量*/ float max=0; int nodelist[20]; /*声明存储输入数据之数组*/ int value; printf(" Please input the elements of binary tree(exit for 0): "); index=0; scanf("%d",&value); /*读取输入值放到变量value*/ while(value!=0) {nodelist[index]=value; index=index+1; scanf("%d",&value); } printf("%d",index); root=create_btree(nodelist,index); printf(" the inorder traversal result is :"); inorder(root); printf(" "); for(m=0;m<index;m++) { tree_search(root,nodelist[m]); max+=counter; /*计算查找长度*/ } printf("the average long is: %.2f ",max/index); /*输出average查找长度*/ getch(); }

利用二叉排序树对顺序表进行排序 (1)生成一个顺序表L;(2)对所生成的顺序表L构造二叉排序树(3)利用栈结构

用C或C++语言实现的功能: (1)生成一个顺序表L; (2)对所生成的顺序表L构造二叉排序树 (3)利用栈结构实现中序遍历二叉排序树; (4)中序遍历所构造的二叉排序树将记录由小到大输出。

急!急!求二叉排序树程序

#include <iostream.h> //二叉排序树类的前视定义 template<class Type> class BSTree; //二叉排序树结点类的定义 template<class Type> class BSTreeNode {friend class BSTree <Type>; private: Type data; //数据域(在此为关键字) BSTreeNode <Type> *leftChild, *rightChild; public: BSTreeNode():leftChild(NULL),rightChild (NULL){};//构造函数 BSTreeNode(const Type &d) : data (d), leftChild (NULL),rightChild (NULL) {} ; //构造函数 ~BSTreeNode(){}; //析构函数 }; //二叉排序树的类定义 template <class Type> class BSTree { private: BSTreeNode<Type> * root; //二叉排序树的根指针 void Insert ( const Type & x, BSTreeNode<Type> *&p ); //在p为根的二叉排序树上插入数据元素x void Delete ( const Type & k, BSTreeNode<Type> *&p ); //在p为根的二叉排序树上删除关键字为k的结点 BSTreeNode<Type> * Min(BSTreeNode<Type> *p); BSTreeNode<Type> * Find(const Type &k, BSTreeNode<Type> *p ); //在p为根的二叉排序树上查找关键字为k的结点 void InOrder(BSTreeNode<Type> *r); public: BSTree() : root (NULL) {}//构造函数 Type Find ( const Type &k ) {//查找 BSTreeNode<Type>* p=Find ( k, root ); if(p==NULL){ cout<<"There is not a node that equals "<<k<<endl; return NULL; } return p->data; } void Insert(const Type &x) { Insert ( x, root ); } //插入 void Delete(const Type &k) { Delete ( k, root ); } //删除 void SortDisplay(){InOrder(root);cout<<endl;} }; template <class Type> void BSTree<Type>:: Insert(const Type &x, BSTreeNode<Type> * &p) { //在p为根的二叉排序树插入结点的递归算法 if ( p == NULL ) //空二叉树 p = new BSTreeNode<Type>(x); //创建数据元素x的结点 else if (x<p->data ) //在左子树插入 Insert ( x, p->leftChild ); else if ( x > p->data ) //在右子树插入 Insert ( x, p->rightChild ); else //结点x已存在 { cout << "There has node x" << endl; } } template <class Type> BSTreeNode<Type> * BSTree<Type> :: Find (const Type &k, BSTreeNode<Type> *p) { //在p为根的二叉排序树上进行查找的递归算法 if ( p == NULL ) return NULL; //查找失败 else if ( k<p->data ) //在左子树上递归查找 return Find (k,p->leftChild ); else if (k>p->data ) //在右子树上递归查找 return Find ( k, p->rightChild ); else return p; //相等,查找成功 } template <class Type> void BSTree<Type> :: Delete(const Type &k, BSTreeNode<Type> * &p){ //在p为根的二叉排序树上删除关键字为k的结点 if ( p != NULL ){ BSTreeNode<Type> * temp; if ( k < p->data ) Delete ( k, p->leftChild ); else if ( k > p->data ) Delete ( k, p->rightChild ); else if ( p->leftChild != NULL && p->rightChild != NULL ){ BSTreeNode<Type> * tparent=p; temp=p->rightChild; while(temp->leftChild!=NULL){ tparent=temp; temp=temp->leftChild; } p->data = temp->data; if(tparent==p) Delete ( p->data,tparent->rightChild ); else Delete ( p->data,tparent->leftChild ); } else { temp = p; if ( p->leftChild == NULL ) p = p->rightChild; else if ( p->rightChild == NULL ) p = p->leftChild; delete temp; } } } template <class Type> void BSTree<Type>::InOrder(BSTreeNode<Type>* r){ if(r!=NULL){ InOrder(r->leftChild); cout<<r->data<<" "; InOrder(r->rightChild); } } void main (){ BSTree<int> a; int x; cout<<"输入序列:"<<" "; for(int i=0;;i++){ cin>>x; if(x==-1)break; a.Insert(x); } cout<<endl; cout<<"输出中序遍历序列应为:"; a.SortDisplay(); cout<<endl; cout<<"输入需要删除的整数:"<<" "; int y; cin>>y; cout<<endl; cout<<"查找结果是:"<<a.Find(y)<<endl; cout<<endl; a.Delete(y); cout<<"输出删除后的中序遍历序列应为:"<<" "; a.SortDisplay(); }

构建二叉排序树,依次输入56,78,34,45,85,45,36,91,84,78,两个45和78

题目中应该几乎没有这种情况吧,像这一题,可以先试着把后一个45插到原45的左子树下(其实右子树下也是一样的)然后按照平衡二叉树的规则去做变换,而结果的78由于本题里前一个78的右子树上已经有了节点了,也只能插在做子树上面。

ps:以上都是个人见解,因为实际中并未见过此例~

Webhosting24:€15/年-AMD Ryzen/512MB/10GB/2TB/纽约&日本&新加坡等机房

Webhosting24是一家始于2001年的意大利商家,提供的产品包括虚拟主机、VPS、独立服务器等,可选数机房包括美国洛杉矶、迈阿密、纽约、德国慕尼黑、日本、新加坡、澳大利亚悉尼等。商家VPS主机采用AMD Ryzen 9 5950X CPU,NVMe磁盘,基于KVM架构,德国机房不限制流量,网站采用欧元计费,最低年付15欧元起。这里以美国机房为例,分享几款套餐配置信息。CPU:1core内存...

快快云:香港沙田CN2/美国Cera大宽带/日本CN2,三网直连CN2 GIA云服务器和独立服务器

快快云怎么样?快快云是一家成立于2021年的主机服务商,致力于为用户提供高性价比稳定快速的主机托管服务,快快云目前提供有香港云服务器、美国云服务器、日本云服务器、香港独立服务器、美国独立服务器,日本独立服务器。快快云专注为个人开发者用户,中小型,大型企业用户提供一站式核心网络云端服务部署,促使用户云端部署化简为零,轻松快捷运用云计算!多年云计算领域服务经验,遍布亚太地区的海量节点为业务推进提供强大...

friendhosting:(优惠55%)大促销,全场VPS降价55%,9个机房,不限流量

每年的7月的最后一个周五是全球性质的“系统管理员日”,据说是为了感谢系统管理员的辛苦工作....friendhosting决定从现在开始一直到9月8日对其全球9个数据中心的VPS进行4.5折(优惠55%)大促销。所有VPS基于KVM虚拟,给100M带宽,不限制流量,允许自定义上传ISO...官方网站:https://friendhosting.net比特币、信用卡、PayPal、支付宝、微信、we...

排序二叉树为你推荐
局域网监控软件求一个破解版局域网监控软件swift语言swift语言坑死ios开发宅这样怎么说呢?有基础入门课程推荐吗nvidia官方网站N卡的官网是什么?资源优化配置如何理解 教育资源优化配置antiarp电脑一开机就出现发现新硬件xAntiArp Miniport,提示安装,很是影响开机速度,怎么办?什么是光纤什么是光纤?什么是宽带?两者有什么不同?硬盘分区格式化电脑进入系统硬盘分区及格式化,怎样操作?工作经验介绍个人工作经历简介要怎么写安全工程师待遇安全工程就业的待遇怎么样,警告本网站内容我的网页一打开,就出安全警告,内容是:当前网页正试图打开您的受信任列表中站点。 该怎么去掉啊????
vps.net 韩国空间 国外bt 谷歌香港 免费个人网站申请 中国电信测速112 如何注册阿里云邮箱 流媒体加速 网站加速软件 lick 东莞服务器托管 lamp是什么意思 深圳域名 腾讯数据库 789电视剧网 汤博乐 wordpress空间 上海联通 cdn加速技术 服务器机柜 更多