DS博客作业07——查找
1.本周学习总结
1.1思维导图
1.2.谈谈你对查找运算的认识及学习体会。
查找的内容和前两章树和图相比,要简单许多,在二次搜索树虽然也要用到树,但是也是很简单的树的操作,再加上查找的代码可以使用map这种STL++容器,使得代码简单而且容易理解。
查找的方法有很多,上学期就基本学过的顺序表的查找(数组嘛),二分法查找,还有二叉搜索树,哈希查找,每种查找方法都有自己的利与弊,有的效率高有的操作简单,使用时要灵活。
map容器的常用操作
map<Key, value> m
map<Key, value> m; 构造一个空的map,
empty() // 如果map 为空,返回true。否则返回 false
ize() // 返回map 中元素的大小,即 key-value 的个数
操作符[] // m[k] 返回map 中 Key为 k的元素的value的引用。
// 如果 k不存在,那么将会插入一个 key为 k的元素,并返回其默认 value。
// []操作总会将 map的大小 +1
find 查找
在map中查找key 为 k的元素,返回指向它的迭代器。若k不存在,返回 map::end.
count 计数
统计map中 key为k的元素的个数,对于map,返回值不是1(存在),就是0(不存在)
2.PTA实验作业
2.1.是否二叉搜索树
2.1.1设计思路
定义全局数组a
中序遍历二叉树
{
if T存在
递归遍历左孩子
得到的数据放入数组a
递归遍历右孩子
}
判断数组a是否升序
{
for j=1 to i
if a[j-1]>a[j]//有一对数据不是升序
return false ;
end if
return true;//全部没问题返回true;
}
2.2.2代码截图
2.2.3本题PTA提交列表说明
利用搜索二叉树的特性,即中序遍历得到的顺序为升序,即可快速解答此题。
2.2.二叉搜索树中的最近公共祖先
2.2.1设计思路
Find(Tree T ,int u)
{
if(!T)
return 0;//找不到
end if
如果Key大于要找的数,去左孩子
如果Key小于要找的数,去右孩子
等于的话返回1
}
LCA(Tree T,int u,int v)
{
if(!T) return REEOR//找不到
end if
Key的大小在v和u之间,那T就是公共祖先 return T->Key
Key等于u和v中的一个,那T也是祖先 return T->Key
如果Key比u和v小,去右孩子找祖先
如果Key比u和v大,去左孩子找祖先
前面的判断中不能跳出,则找不到 return ERROR
}
2.2.2代码截图
2.2.3本题PTA提交列表说明
2.3QQ帐户的申请与登陆
2.3.1设计思路
本题主要是练习map容器的使用
头文件 #include
默认定义方式 map m;
key为搜索的关键字 ,value为对应的值(主要数据类型)
map<string,int> account;//账号
map<string,string> code;//密码
输入x,y,z //y 账号 z 密码
如果 xL //老用户登录
if account[y]0 //账号不存在
输出ERROR: Not Exist4
else if code[y]!=z//账号存在但密码不对
输出ERROR: Wrong PW
end if
if account[y]1&&code[y]=z//账号存在且密码正确
输出Login: OK
end if
如果 xN//新用户注册
if account[y]1//账号已被注册
输出ERROR: Exist
end if
if account[y]0//账号没有被注册
account[y]=1;
code[y]=z;
输出New: OK
end if
2.3.2代码截图
2.3.3本题PTA提交列表说明
阅读代码
解题思路
* 先比较第一和第二个,如果有公共的前缀,则用前缀和第三个比较
* 如果没有公共前缀,就直接返回,后面的不需要比较
代码截图
题目是在力扣上找的,网站上提供了好多解题思路。我觉得这是最好最清楚的,从头开始逐个遍历,时间复杂杜并不是很高,但思路很清晰,用代码写出来也很简单。
DS博客作业07——查找的更多相关文章
- DS博客作业--07查找
目录 DS博客作业--07查找 1.本周学习总结(0--2分) 1.思维导图 2.谈谈你对查找运算的认识及学习体会. 2.PTA实验作业(6分) 2.1.题目1:6-1 二叉搜索树的操作集 (30 分 ...
- DS博客作业07—查找
1.本周学习总结 1.1思维导图 1.2学习体会 本章学习了顺序表.树表.哈希表的查找方式,学会计算各种查找方式下的ASL 树表部分的b树和平衡二叉树较为复杂,哈希表相对容易掌握 期末要复习的有点多, ...
- DS博客作业——树
DS博客作业--树 1.本周学习总结 1.思维导图 2.谈谈你对树结构的认识及学习体会. 在树这一章节,我们学习的是二叉树的算法. 树的构建:一种是直接给树的顺序存储结构的字符串,一种是通过先序遍历和 ...
- DS博客作业05--查找
这个作业属于哪个班级 数据结构--网络2011/2012 这个作业的地址 DS博客作业05--查找 这个作业的目标 学习查找的相关结构 姓名 黄静 目录 0.PTA得分截图 1.本周学习总结 1.1 ...
- DS博客作业04--图
这个作业属于哪个班级 数据结构--网络2011/2012 这个作业的地址 DS博客作业04--图 这个作业的目标 学习图结构设计及相关算法 姓名 黄静 目录 0.PTA得分截图 1.本周学习总结 1. ...
- DS博客作业03--树
这个作业属于哪个班级 数据结构--网络2011/2012 这个作业的地址 DS博客作业03--树 这个作业的目标 学习树结构设计及运算操作 姓名 黄静 目录 0. PTA得分截图 1. 本周学习总结 ...
- DS博客作业08--课程总结
DS博客作业08--课程总结 1.当初你是如何做出选择计算机专业的决定的? 1.1 经过一年学习,你的看法改变了么,为什么? 1.2 你觉得计算机是你喜欢的领域吗,它是你擅长的领域吗? 为什么? 1. ...
- DS博客作业--课程总结
1.当初你是如何做出选择计算机专业的决定的? 经过一年学习,你的看法改变了么,为什么? 你觉得计算机是你喜欢的领域吗,它是你擅长的领域吗? 为什么? 刚开始填报志愿的时候,因为我个人是没有什么比较特别 ...
- DS博客作业01--线性表
1.本周学习总结(0--2分) 1.1思维导图 1.2.谈谈你对线性表的认识及学习体会. 1.线性表的内容上了三星期的课,相对来说内容比较丰富,尤其是链表方面,包含单链表,双链表和循环链表.作为第一部 ...
随机推荐
- IEnumerable<T>和IQuryable<T>的区别
https://stackoverflow.com/questions/1578778/using-iqueryable-with-linq/1578809#1578809 The main diff ...
- vue-添加全局扩展方法
1.添加全局方法或者属性,如: vue-custom-element 2.添加全局资源:指令/过滤器/过渡等,如 vue-touch 3.通过全局 mixin 方法添加一些组件选项,如: vue-ro ...
- win10 增加一个新磁盘
1.右键我的电脑,选择管理 可以看到C盘的空间相比较大,拿出来250G的空间做成E盘 2.选择OS(C:),右键,压缩卷,请稍后,点击压缩 3.此刻会看到,有一块黑色区域就是新建的未分配空间,这时我们 ...
- 小程序Flex布局
容器属性 容器支持的属性有:display:通过设置display属性,指定元素是否为Flex布局.flex-direction:指定主轴方向,决定了项目的排列方式.flex-wrap:排列换行设置. ...
- GOLANG文件拷贝
GOLANG文件拷贝 在Golang中,使用系统自带函数io.Copy() 如: srcFile := "C:/Users/Wisdom/Desktop/Wisdompic.png" ...
- linux firewall指令
CentOS7中firewall防火墙详解和配置,.xml服务配置详解修改防火墙配置文件之前,需要对之前防火墙做好备份 重启防火墙后,需要确认防火墙状态和防火墙规则是否加载,若重启失败或规则加载失败, ...
- Gym - 101170B British Menu SCC点数目不超过5的最长路
题意其实就是给你一个有向图 但是每个SCC里面的点数目不超过5 求最长路 首先暴力把每个SCC里的每个点的最长路跑出来 然后拓扑排序dp 然后因为tarjan 搜索树出来的SCC是拓扑排好序的 可以直 ...
- 《黑白团团》第九次团队作业:Beta冲刺与验收准备
项目 内容 作业课程地址 任课教师首页链接 作业要求 团队项目 填写团队名称 黑白团团队 填写具体目标 认真负责,完成项目 GitHub链接 Scrum meeting导航 [Beta]Scrum m ...
- mpvue打小程序预览码
喂,快给我打一个小程序预览码 前端大全 昨天 (点击上方公众号,可快速关注) 来源:写Bug segmentfault.com/a/1190000015336845 需求 开发小程序的朋友们随时都会听 ...
- 【Linux】解决用vi修改文件,保存文件时,提示“readonly option is set”
当在终端执行sudo命令时,系统提示“hadoop is not in the sudoers file”: 其实就是没有权限进行sudo,解决方法如下(这里假设用户名是cuser): 1.切换到超级 ...