数据结构回顾及展望(一)
时间:2022-07-25
本文章向大家介绍数据结构回顾及展望(一),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
万丈高楼平地起
难题也由水题起
只有珍惜自己是小兵的日子,才能成为如将军般运筹帷幄之中,决胜千里之外------------前言
树形数据结构
FBI树解析:后序遍历的模板
一般后序遍历的代码是:
void postbintree(node*p)
{
if(!p)return ;
postbintree(p->leftchild);
postbintree(p->rightchild);
cout<<p->data<<" ";
}
按图索骥,此题也是一个道理
实际上读入的n没有用,起作用的是字符串,按题目要求,不断对字符串进行二等分,按照后序遍历思想操作即可
#include<bits/stdc++.h>
using namespace std;
int n;
string s;
char fbi(string s)
{
if(s.length()>1)
{
cout<< fbi(s.substr(0,s.length()/2));
cout<< fbi(s.substr(s.length()/2,s.length()/2));
}
if(s==string(s.length(),'0'))return 'B';
if(s==string(s.length(),'1'))return 'I';
return 'F';
}
int main()
{
cin>>n>>s;
cout<<fbi(s);
return 0;
}
求先序遍历题目的思想也类似,但要注意已知先序和中序推得后序,中序和后序可以推得先序,但先序和后序不能推得中序
献上很短的递归代码
#include<bits/stdc++.h>
using namespace std;
string a,b;
void dfs(int l1,int r1,int l2,int r2)
{
int m=a.find(b[r2]);
cout<<a[m];
if(m>l1)dfs(l1,m-1,l2,r2-(r1-m)-1);
if(m<r1)dfs(m+1,r1,l2+m-r1,r2-1);
return ;
}
int main()
{
cin>>a>>b;
dfs(0,a.size()-1,0,b.size()-1);
return 0;
}
解释几个难点,按照题目要求我只知道中序和后序,那后序最后一个一定在中序的位置是它的左子树和右子树的分界线
我只要找到了这个位置并记录下来,在中序排列中这个位置-起始点=这个位置的data所代表的父节点的左子树长度,结束点-在中序排列中这个位置=这个位置的data所代表的父节点的右子树长度,又依据后序遍历是左子树,右子树,根节点的顺序,我只要将下次递归的范围改成后序遍历起点到(结束点-右子树长度)即可,当然要记得-1,因为我们输出了一个结点信息,它的使命已经完成
新二叉树分析:
可以采用stl的字符串函数
这个题可以算是二叉树的模板题吧。
首先要明白二叉树中先序,中序,后序遍历的概念。
其实这里的先,中,后都是根节点出现的位置,其他都是左子树先于右子树遍历。注意这里左子树和右子树也适合子树,也就是说遍历是递归进行的。
例如样例:
先序为 abdicj
中序为 dbjacj
后序为 dbicja
由于此题字符串第一个默认根节点,又是按顺序来的先序遍历,,所以很好水过
#include<bits/stdc++.h>
using namespace std;
int n;
string s;
int main()
{
cin>>n>>s;
for(int i=2;i<=n;i++)
{
string sontree;
cin>>sontree;
int k=s.find(sontree[0]);
s.erase(k,1);
s.insert(k,sontree);
}
for(int i=0;i<(signed)s.size();i++)
{
if(s[i]=='*')continue;
cout<<s[i];
}
return 0;
}
但如果不是第一个要怎么办呢?思路:记录树中每个节点的父亲,最后在遍历一遍找到没有父亲的节点即为根节点
- Linux shell 程序设计4——shell变量
- 基于CallContextInitializer的WCF扩展导致的严重问题
- 1228-redux学习笔记(摘录) | WEB前端零基础课
- 在fedora下使用搜狗拼音输入法
- 一个通过JSONP跨域调用WCF REST服务的例子(以jQuery为例)
- 【1120-WEB零基础课】| 单例模式,下周要讲
- 使用gerrit作为代码评审工具
- 如何重构你的时间序列预测问题
- 【聊】我个人眼里的ReactJs生态系统
- [WCF REST] Web消息主体风格(Message Body Style)
- apache配置https服务
- [WCF 4.0新特性] 默认绑定和行为配置
- mysql数据库及django用户名启用中文的方法
- 【学习笔记】先行者课程0109-rotate3d_变量、堆、栈
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Flutter Dojo设计之道——利用Github打造完善的开源项目
- 最强 Redis 客户端 lettuce 已支持 Redis6客户端
- 还在手动整理数据库文档?试试这个工具
- Elasticsearch 常见的 8 种错误及最佳实践
- Spark流式状态管理
- Scala中的IO操作及ArrayBuffer线程安全问题
- 设计模式之单例模式
- Roslyn 理解 msbuild 的清理过程
- gorm聚合查询group结合join和count
- 潘石屹用Python解决100个问题 | 集合
- Catalina 默认使用zsh了,你可习惯
- LeetCode 354 Russian Doll Envelopes (动态规划)
- 设计模式之原型模式
- 设计模式之工厂方法模式
- Python 随机数生成