2004.11.04

  1. 计算一颗给定二叉树的所有双分支节点个数
  2. 编写把一个树的所有左右子树进行交换的函数
  3. 求先序遍历中第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

  1. 二叉树以二叉链表存储 求非空二叉树的宽度
#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; }
//--------------------------------------------------------------
  1. 将给定的表达式树 转换为等价的中缀表达式并输出

叶子结点肯定是操作数,非叶子结点就是运算符

#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语言版)的更多相关文章

  1. c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...

  2. 数据结构C语言版 有向图的十字链表存储表示和实现

    /*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...

  3. 数据结构C语言版 表插入排序 静态表

    数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./*  数据结构C语言版 表插入排序  算法10.3 P267-P270  编译 ...

  4. 数据结构C语言版 弗洛伊德算法实现

    /* 数据结构C语言版 弗洛伊德算法  P191 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h>#include <limits.h> # ...

  5. 《数据结构-C语言版》(严蔚敏,吴伟民版)课本源码+习题集解析使用说明

    <数据结构-C语言版>(严蔚敏,吴伟民版)课本源码+习题集解析使用说明 先附上文档归类目录: 课本源码合辑  链接☛☛☛ <数据结构>课本源码合辑 习题集全解析  链接☛☛☛  ...

  6. 二叉树的基本操作(C语言版)

    今天走进数据结构之二叉树 二叉树的基本操作(C 语言版) 1 二叉树的定义 二叉树的图长这样: 二叉树是每个结点最多有两个子树的树结构,常被用于实现二叉查找树和二叉堆.二叉树是链式存储结构,用的是二叉 ...

  7. 深入浅出数据结构C语言版(12)——从二分查找到二叉树

    在很多有关数据结构和算法的书籍或文章中,作者往往是介绍完了什么是树后就直入主题的谈什么是二叉树balabala的.但我今天决定不按这个套路来.我个人觉得,一个东西或者说一种技术存在总该有一定的道理,不 ...

  8. 【数据结构(C语言版)系列二】 栈

    栈和队列是两种重要的线性结构.从数据结构角度看,栈和队列也是线性表,但它们是操作受限的线性表,因此,可称为限定性的数据结构.但从数据类型角度看,它们是和线性表大不相同的两类重要的抽象数据类型. 栈的定 ...

  9. 深入浅出数据结构C语言版(5)——链表的操作

    上一次我们从什么是表一直讲到了链表该怎么实现的想法上:http://www.cnblogs.com/mm93/p/6574912.html 而这一次我们就要实现所说的承诺,即实现链表应有的操作(至于游 ...

  10. 深入浅出数据结构C语言版(1)——什么是数据结构及算法

    在很多数据结构相关的书籍,尤其是中文书籍中,常常把数据结构与算法"混合"起来讲,导致很多人初学时对于"数据结构"这个词的意思把握不准,从而降低了学习兴趣和学习信 ...

随机推荐

  1. struts2框架详解

    struts2框架(1)---struts2入门 struts2框架 如果你之前在MVC模式的时候一直都是通过servlet,获取和返回数据,那么现在开始学习struts2框架, Struts是一个实 ...

  2. 初识MinIO

    writer:zgx last modify: 2020年09月26日 目录 前言 MinIO简介 MinIO使用 MinIO安装 MinIO纠删码 纠删码ensure code是什么 refers ...

  3. C 国家名字按字母顺序排序

    问题 输入五个国家的名字,并按字母的顺序排列输出 分析 知识点 strcpy(1,2):将字符串2复制到字符数组1中    strcmp(1,2):比较字符串大小 二维数组 代码 #include & ...

  4. 0101-win10 jkd配置注意事项

    更换新的电脑预装win10家庭版,根据常规方法配置jdk8后运行javac提示:不是内部或外部命令,也不是可运行的程序或批处理文件. 1 设置变量classpath时前面有个点(完成这一步后javac ...

  5. Brainfly: 用 C# 类型系统构建 Brainfuck 编译器

    Brainfuck 简介 Brainfuck 是由 Urban Müller 在 1993 年创造的一门非常精简的图灵完备的编程语言. 正所谓大道至简,这门编程语言简单到语法只有 8 个字符,每一个字 ...

  6. Luogu P7077 CSP-S2020 函数调用 题解 [ 蓝 ] [ 拓扑排序 ] [ 动态规划 ] [ 数学 ]

    函数调用:个人非常喜欢的一道拓扑题. 转化 这题一共有三种操作,不太好搞.而第一个函数看起来就比较可做,第三个函数显然就是让你拓扑转移,于是我们考虑第二个操作怎么处理. 当我们进行一个操作一后,假设当 ...

  7. P1081 [NOIP 2012 提高组] 开车旅行 题解

    传送门 前言 爆肝到半夜,中间假了一次,最终调过了两个样例,交上去过了. 题解 思路 首先进行预处理. 用一种你喜欢的数据结构维护每个城市的海拔,容易求出从每个城市出发,小 \(A\) 和小 \(B\ ...

  8. datawhale-leetcode打卡:001-012题

    这次这十二个题目属于是极限肝出来的,有两个参考了一下题解,还是很有意思.我会按照我个人的感觉去写这个东西. 螺旋矩阵(leetcode 054) 这个题目比较恶心的就是跑圈的过程怎么描述.首先,顺时针 ...

  9. [HDU5603] the soldier of love 题解

    考虑到正向求解困难,于是正难则反. 那么实际上对于 \(a_i\) 和 \(a_{i+1}\) 来说,它们给答案的贡献就是满足 \(l_j>a_i,r_j<a_{i+1}\) 的区间数量. ...

  10. [SCOI2016] 幸运数字 题解

    \(xor\) 最大值想到线性基,路径想到 \(lca\) 和树链剖分,由于没有修改用 \(lca\) 就可以.先用处理 \(fa\) 数组的方式处理倍增线性基(自然是得用线性基合并的),在求 \(l ...