社区
数据结构与算法
帖子详情
求一个C++的二叉书生成算法
MikeWEE
2007-08-21 06:23:33
求一个C++的二叉书生成算法。找了好多地方,看了好多书,都没有讲这个,请高人指点!!
...全文
162
3
打赏
收藏
求一个C++的二叉书生成算法
求一个C++的二叉书生成算法。找了好多地方,看了好多书,都没有讲这个,请高人指点!!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
3 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
可爱的小莱
2007-09-15
打赏
举报
回复
//bitree.h
//定义二叉树的节点
typedef struct node{
BiTree *lchild, *rchild;
struct node * next;
}Node ,*BiTree;
class BiTree{
publc:
BiTree * CreateBiTree( BiTree * T)
private:
};
*********************************************
//BiTree.cpp
void CreateBiTree( BiTree * T)
{
manrenmanren
2007-08-21
打赏
举报
回复
二叉树就是最普通的吧
应该不是特指平衡二叉树
kgn28
2007-08-21
打赏
举报
回复
什么二叉树?平衡二叉树???
这是一个平衡二叉树的标准程序:
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include<string.h>
#define Boolean int
#define TRUE 1
#define FALSE 0
typedef struct treespe{
char key[30];
float treesum;
}treespe;
#define ElemType treespe
#define EQ(a,b) (!strcmp(a,b))
#define LT(a,b) (strcmp(a,b)<0)
#define Status int
typedef struct BSTNode{
ElemType data;
int bf;
struct BSTNode *lchild,*rchild;
}BSTNode,*BSTree;
int N,flag;
#define LH 1
#define EH 0
#define RH -1
void R_Rotate(BSTree &p);
void L_Rotate(BSTree &p);
void LeftBalance(BSTree &T);
void RightBalance(BSTree &T);
Status InsertAVL(BSTree &T,ElemType e,Boolean &taller);
int print(BSTree T);
void freetree(BSTree T);
int main()
{
int i=0;
ElemType e;
Boolean taller;
BSTree T=NULL;
scanf("%d\n",&N);
while(N!=0){
for(i=0;i<N;i++){
gets(e.key);
e.treesum=0;
InsertAVL(T,e,taller);
}
print(T);
T=NULL;
// freetree(T);
scanf("%d\n",&N);
}
return 0;
}
void R_Rotate(BSTree &p)
{
BSTree lc;
lc=p->lchild;
p->lchild=lc->rchild;
lc->rchild=p;
p=lc;
}
void L_Rotate(BSTree &p)
{
BSTree rc;
rc=p->rchild;
p->rchild=rc->lchild;
rc->lchild=p;
p=rc;
}
void LeftBalance(BSTree &T)
{
BSTree lc,rd;
lc=T->lchild;
switch(lc->bf){
case LH:
T->bf=lc->bf=EH;
R_Rotate(T);
break;
case RH:
rd=lc->rchild;
switch(rd->bf){
case LH:
T->bf=RH;
lc->bf=EH;
break;
case EH:
T->bf=lc->bf=EH;
break;
case RH:
T->bf=EH;
lc->bf=LH;
break;
}
rd->bf=EH;
L_Rotate(T->lchild);
R_Rotate(T);
}
}
void RightBalance(BSTree &T)
{
BSTree rc,ld;
rc=T->rchild;
switch(rc->bf){
case RH:
T->bf=rc->bf=EH;
L_Rotate(T);
break;
case LH:
ld=rc->lchild;
switch(ld->bf){
case LH:
T->bf=EH;
rc->bf=RH;
break;
case EH:
T->bf=rc->bf=EH;
break;
case RH:
T->bf=LH;
rc->bf=EH;
break;
}
ld->bf=EH;
R_Rotate(T->rchild);
L_Rotate(T);
}
}
Status InsertAVL(BSTree &T,ElemType e,Boolean &taller)
{
if(!T){
e.treesum++;
T=(BSTree)malloc(sizeof(BSTNode));
T->data=e;
T->lchild=T->rchild=NULL;
T->bf=EH;
taller=TRUE;
}else {
if(EQ(T->data.key,e.key)){
T->data.treesum++;
taller=FALSE;
return 0;
}
if(LT(e.key,T->data.key)){
if(!(InsertAVL(T->lchild,e,taller)))return 0;
if(taller){
switch(T->bf){
case LH:
LeftBalance(T);
taller=FALSE;
break;
case EH:
T->bf=LH;
taller=TRUE;
break;
case RH:
T->bf=EH;
taller=FALSE;
break;
}
}
}else {
if(!InsertAVL(T->rchild,e,taller))return 0;
if(taller){
switch(T->bf){
case LH:
T->bf=EH;
taller=FALSE;
break;
case EH:
T->bf=RH;
taller=TRUE;
break;
case RH:
RightBalance(T);
taller=FALSE;
break;
}
}
}
}
return 1;
}
int print(BSTree T)
{
if(T!=NULL){
if(T->data.treesum>=N/2){
printf("Case %d:\n%s\n",++flag,T->data.key);
return 0;
}
print(T->lchild);
print(T->rchild);
}
return 0;
}
void freetree(BSTree T)
{
if(T->lchild)freetree(T->lchild);
if(T->rchild)freetree(T->rchild);
free(T);
}
<4>数据结构与
算法
(C/
C++
实现)视频教程
C/
C++
实现数据结构与
算法
视频培训课程全面介绍计算机行业,基本的数据结构与
算法
,既有理论的深度也有实战的技法。课程全程讲师手敲代码,一步步代你走进数据结构与
算法
。本课程涉及的数据结构与
算法
有,栈,队列,单向链表,双向循环链表,树,
二叉
树,搜索
二叉
树,平衡搜索
二叉
树,冒泡,选择,直插,希尔,,归并等,课程还涉及深度优先
算法
与广度优先
算法
等等。
Leetcode-230.
二叉
搜索树中第K小的元素
链接 230.
二叉
搜索树中第K小的元素 题目 给定
一个
二叉
搜索树的根节点root,和
一个
整数k,请你设计
一个
算法
查找其中第k个最小元素(从 1 开始计数)。 示例 示例 1: 输入:root = [3,1,4,null,2], k = 1 输出:1 示例 2: 输入:root = [5,3,6,2,4,null,null,1], k = 3 输出:3 说明 树中的节点数为n。 1 <= k <= n <= 104 0 <=...
LeetCode--98. 验证
二叉
搜索树
C++
描述)
题目分析
一个
比较笨的方法就是将元素依次放入数组中,然后遍历数组,如果出现后
一个
元素大于前
一个
元素的话就返回false。给你
一个
二叉
树的根节点root,判断其是否是
一个
有效的
二叉
搜索树。输入root=[5,1,4,null,null,3,6]解释根节点的值是5,但是右子节点的值是4。所有左子树和右子树自身必须也是
二叉
搜索树。节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。树中节点数目范围在[1,104]内。输入root=[2,1,3]...
Leetcode-235.
二叉
搜索树的最近公共祖先
链接 235.
二叉
搜索树的最近公共祖先 题目 给定
一个
二叉
搜索树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为
一个
结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(
一个
节点也可以是它自己的祖先)。” 例如,给定如下
二叉
搜索树:root =[6,2,8,0,4,7,9,null,null,3,5] 示例 例如,给定如下
二叉
搜索树: root = [6,2,8,0,4,7,9,null...
LeetCode--230.
二叉
搜索树中第K小的元素(
C++
描述)
题目分析:
二叉
搜索树的中序遍历可以将树中的元素从小到大输出,因此我们使用中序遍历进行
求
解,每次循环递减k,当k递减到0时说明当前root指针指向的节点就是所
求
节点。给定
一个
二叉
搜索树的根节点 root ,和
一个
整数 k ,请你设计
一个
算法
查找其中第 k 个最小元素(从 1 开始计数)。输入:root = [5,3,6,2,4,null,null,1], k = 3。输入:root = [3,1,4,null,2], k = 1。树中的节点数为 n。
数据结构与算法
33,008
社区成员
35,326
社区内容
发帖
与我相关
我的任务
数据结构与算法
数据结构与算法相关内容讨论专区
复制链接
扫一扫
分享
社区描述
数据结构与算法相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章