二叉树 (王道数据结构 C语言版)
2004.11.04
- 计算一颗给定二叉树的所有双分支节点个数
- 编写把一个树的所有左右子树进行交换的函数
- 求先序遍历中第k个结点的值 (1 <= k <= 二叉树中的结点个数)
#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
typedef struct Bitnode{
int data;
struct Bitnode *lc,*rc;
}Bitnode,*Bitree;
//-------------------------------------------------------------------------
//王道数据结构 P158 T07
//计算一颗给定二叉树的所有双分支节点个数
int getnum(Bitree T)
{
if(T==NULL) return 0; //若b为空则贡献0
else if(T->lc && T->rc) return getnum(T->lc)+getnum(T->rc)+1;//有左右节点,贡献给上一层+1
else return getnum(T->rc)+getnum(T->lc); //只有一个节点则归到上一层 数量不变
}
//----------------------------------------------------------------------------------
//王道数据结构 P158 T07
//编写把一个树的所有左右子树进行交换的函数
void swaptree(Bitree T)
{
if(T==NULL) return;
else if(T->lc && T->rc) {
swaptree(T->lc); //递归进左子树
swaptree(T->rc);//递归进右子树
swap(T->lc,T->rc);
}
}
//-------------------------------------------------------------------------
//王道数据结构 P158 T09
//求先序遍历中第k个结点的值 (1 <= k <= 二叉树中的结点个数)
//---------------------版本1(自写版)------------------
int idx=1;
void getknode (Bitree T,int k)
{
if(T==NULL ) return ;
if(idx==k) {
cout<<T->data;
return ;
}
idx++;
getknode(T->lc,k);
getknode(T->rc,k);
}
//---------------------王道答案版--------------------
int i=1;
ElemType prenode(Bitree T,int k)
{
if(T==NULL) return '#' ; //空结点 返回特殊字符
if(i==k) return T->data;
i++;
char ch=prenode(T->lc,int k);//进左子树查找
if(ch!='#') return ch; //如果空结点返回的元素值没有意义
char ch=prenode(T->rc,int k);
if(ch!='#') return ch;
}
2024.11.08
- 二叉树以二叉链表存储 求非空二叉树的宽度
#include<bits/stdc++.h>
#define endl '\n'
using namespace std;
#define Maxsize 150
typedef struct Bitnode {
int data;
struct Bitnode *lc,*rc;
} Bitnode,*Bitree;
//王道数据结构 P159 T13
//-----------二叉树以二叉链表存储 求非空二叉树的宽度------------
typedef struct {
int front, rear;
int level[Maxsize];//存层次的序号
Bitree data[Maxsize];//存元素
} Queue;
int getwidth(Bitree T, Queue Q) {
Bitree p;//工作指针
int k;//用来更新层次下标
Q.front = Q.rear = -1;
Q.rear++;//元素入队
Q.data[Q.rear] = T; //根节点入队
Q.level[Q.rear] = 1;
while (Q.front < Q.rear) {
//取出队头
Q.front++;
p = Q.data[Q.front];
k = Q.level[Q.front];
if (p->lc) { //左孩子入队
Q.rear++;
Q.data[Q.rear] = p->lc;
Q.level[Q.rear] = k + 1; //更改对应的层次
}//注意 不可以写成else if
if (p->rc) { //右孩子入队
Q.rear++;
Q.data[Q.rear] = p->rc;
Q.level[Q.rear] = k + 1;;
}
}
int Max=0;//统计最大宽度
int i=0;//移动指针
int tmp=0;//统计对应层次序号的数量
k=1;
//遍历统计最大值
while(i<=Q.rear)
{
tmp=0;
while(i<=Q.rear && Q.level[i]==k)
{
tmp++;
i++;
}
k=Q.level[i];
if(tmp>Max) Max=tmp;
}
return Max;
}
//--------------------------------------------------------------
- 将给定的表达式树 转换为等价的中缀表达式并输出
叶子结点肯定是操作数,非叶子结点就是运算符
#include<bits/stdc++.h>
#define endl '\n'
using namespace std;
//王道数据结构 P159 T18
//将给定的表达式树 转换为等价的中缀表达式并输出
//注意表达式树的叶子结点 肯定是操作数
//根节点和叶子结点不加括号, 其余记得添加括号
typedef struct node{
char data[10];
struct node *left ,*right;
}BTree;
void getin(BTree *T,int dep)
{
if(T==NULL) return ;
else if(!T->left && !T->right) //叶子结点 输出操作数
{
cout<<T->data;
}else {
if(dep>1) cout<<"(";//若有子表达式 则加一层括号
getin(T->left,dep+1);
cout<<T->data; //输出操作符
getin(T->right,dep+1);
if(dep>1) cout<<")";//若有子表达式加一层括号
}
}
void BtreeToe(BTree *T)
{
getin(T,1);//从根节点进入
}
signed main() {
}
二叉树 (王道数据结构 C语言版)的更多相关文章
- c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载
百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...
- 数据结构C语言版 有向图的十字链表存储表示和实现
/*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...
- 数据结构C语言版 表插入排序 静态表
数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./* 数据结构C语言版 表插入排序 算法10.3 P267-P270 编译 ...
- 数据结构C语言版 弗洛伊德算法实现
/* 数据结构C语言版 弗洛伊德算法 P191 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h>#include <limits.h> # ...
- 《数据结构-C语言版》(严蔚敏,吴伟民版)课本源码+习题集解析使用说明
<数据结构-C语言版>(严蔚敏,吴伟民版)课本源码+习题集解析使用说明 先附上文档归类目录: 课本源码合辑 链接☛☛☛ <数据结构>课本源码合辑 习题集全解析 链接☛☛☛ ...
- 二叉树的基本操作(C语言版)
今天走进数据结构之二叉树 二叉树的基本操作(C 语言版) 1 二叉树的定义 二叉树的图长这样: 二叉树是每个结点最多有两个子树的树结构,常被用于实现二叉查找树和二叉堆.二叉树是链式存储结构,用的是二叉 ...
- 深入浅出数据结构C语言版(12)——从二分查找到二叉树
在很多有关数据结构和算法的书籍或文章中,作者往往是介绍完了什么是树后就直入主题的谈什么是二叉树balabala的.但我今天决定不按这个套路来.我个人觉得,一个东西或者说一种技术存在总该有一定的道理,不 ...
- 【数据结构(C语言版)系列二】 栈
栈和队列是两种重要的线性结构.从数据结构角度看,栈和队列也是线性表,但它们是操作受限的线性表,因此,可称为限定性的数据结构.但从数据类型角度看,它们是和线性表大不相同的两类重要的抽象数据类型. 栈的定 ...
- 深入浅出数据结构C语言版(5)——链表的操作
上一次我们从什么是表一直讲到了链表该怎么实现的想法上:http://www.cnblogs.com/mm93/p/6574912.html 而这一次我们就要实现所说的承诺,即实现链表应有的操作(至于游 ...
- 深入浅出数据结构C语言版(1)——什么是数据结构及算法
在很多数据结构相关的书籍,尤其是中文书籍中,常常把数据结构与算法"混合"起来讲,导致很多人初学时对于"数据结构"这个词的意思把握不准,从而降低了学习兴趣和学习信 ...
随机推荐
- net core 中的[FromBody]
一.针对.net core中post类型的api注意的地方(前提是Controller上加[ApiController]特性).默认是这个. 1.如果客户端Content-Type是applicati ...
- 深入LinkedBlockingQueue实现原理
学习BlockingQueue之LinkedBlockingQueue实现原理 一:概念 LinkedBlockingQueue是一个用链表实现的有界阻塞队列.此队列的默认和最大长度为 Integ ...
- Netty的实现原理、特点与优势、以及适用场景
Netty 1.介绍 Netty是由JBOSS提供的一个java开源框架. Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持.作为当前最流行的NIO框架,Ne ...
- FIDO 密钥登录
FIDO 密匙登录 [1]介绍了一些基础密码知识,科普性较好,在此摘抄一下: 说起密码,你会想起什么? 密码太多,记不住? 图省事所有网站用同一个密码,一个泄露了,手忙脚乱地去改密码? 网站被脱库,数 ...
- 使用SOUI4的脚本模块
SOUI4.1提供了全新的lua脚本模块支持,使用这个新版本的脚本模块,可以轻松将所有UI布局及业务逻辑全部使用XML+LUA实现,基本上就是一个超轻型浏览器. SOUI4.0相对于SOUI3最大的区 ...
- 让 LLM 来评判 | 评估你的评估结果
评估你的评估结果 这是 让 LLM 来评判 系列文章的第三篇,敬请关注系列文章: 基础概念 选择 LLM 评估模型 设计你自己的评估 prompt 评估你的评估结果 奖励模型相关内容 技巧与提示 在生 ...
- [国家集训队] Tree2 题解
加边删边 \(LCT\),标记下放同 \(luogu\) 线段树 \(2\) 一题. 时间复杂度 \(O(n\log n)\),第一次交的时候我维护 \(sum\) 不维护 \(sz\ WA\) 完了 ...
- 职场软素质&算法工程师的硬素质--卓越的职场人需要的42种能力
经过自己在实际的工作中摸爬滚打,个人觉得一些方面的能力是非常重要的,可以让自己在职场中快速的脱颖而出,因此,从硬实力,软实力两个方面进行总结如下: 软实力: (1)解决问题的能力 (2)预估风险的能力 ...
- Week09_day05(Hbase的介绍和工作原理)
HBase是一个分布式的.面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文"Bigtable:一个结构化数据的分布式存储系统".就像Bigtable利 ...
- [AI/GPT/Chat2SQL/RAG] VannaAI
概述:VaanaAI 缘起 使用 AI 生成 SQL 的原因 数据仓库和数据湖在企业中广泛应用,但能够精通 SQL 并理解企业数据结构的人很少.AI 可以帮助商业用户使用自然语言查询数据库,生成 SQ ...