二叉树 (王道数据结构 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)——什么是数据结构及算法
在很多数据结构相关的书籍,尤其是中文书籍中,常常把数据结构与算法"混合"起来讲,导致很多人初学时对于"数据结构"这个词的意思把握不准,从而降低了学习兴趣和学习信 ...
随机推荐
- excel表格里面数据统计有几个(相同的算1个)
例如:1 2 3 4 5 6 7 1 2 3 统计出来的结果 是 7个! 相同的算1个. 假设数据在A1:A10区域内,在B1单元格中显示结果,则在B1单元格中输入公式: =SUMPRODUCT(1/ ...
- spandsp_start_dtmf的bug及修复
概述 freeswitch是一款简单好用的VOIP开源软交换平台. 之前的文章中介绍过DTMF从2833到inband的转换,其中inband到2833的转换使用了"spandsp_star ...
- NAT原理:概念、使用场景、转发流程及规则
本文分享自天翼云开发者社区<NAT原理:概念.使用场景.转发流程及规则>,作者:x****n 网络地址转换(NAT)是一种在计算机网络中将一个网络的IP地址转换为另一个网络的IP地址的技术 ...
- Flask+flask-socketio+jsonrpc组合配置避坑
Flask+flask-socketIO+jsonrpc这种组合能被我套出来也是离谱,事先声明:出现这种组合是因为本人之前对flask框架的使用仅限于flask+jsonrpc,所以导致这种情况出现, ...
- galaxy特色胡思乱想
有没有什么办法,让我不伤害任何人,什么也不破坏,被判死刑.我觉得这样比我紫砂要好的多. 我所可怜的是神不能紫砂.--芥川龙之介<某傻子的一生>
- shell 变量的运算、保存硬件信息脚本
变量的数学运算 方法一:expr ##加减乘除 [root@localhost ~]# num1=10[root@localhost ~]# num2=16[root@localhost ~]# ex ...
- calcite-avatica数据传输时对日期类型压缩,导致客户端展示数据异常问题排查
一.背景 用户使用如下sql来获取周开始和结束时间,直连presto查询该sql,得到的week_start=2019-12-30,而通过calcite-avatica查询出结果为week_start ...
- 【忍者算法】从入环点到相遇点:深入理解环形链表 II|LeetCode第142题 环形链表 II
[忍者算法]从入环点到相遇点:深入理解环形链表 II|LeetCode第142题 问题升级:不止要找环,还要找入环点 在上一题中,我们讨论了如何判断链表是否有环.现在让我们更进一步:如果确定链表中有环 ...
- [TJOI/HEOI2016] 求和 题解
为什么又是佳媛姐姐啊啊啊! 斯特林数在这道题中不好处理,直接拆开: \[f(n)=\sum_{i=0}^n\sum_{j=0}^i\begin{Bmatrix}i\\j\end{Bmatrix}2^j ...
- 类的public, private, protected有什么区别?
如何区别C# private和protected? 一.通过使用来区分 1.private:编程语句在模块级别中使用,用于声明私有变量及分配存储空间. 2.protected:编程语句在模块级别中使用 ...