博客作业05--查找
1.学习总结(2分)
1.1查找的思维导图
1.2 查找学习体会
- 查找这一章的知识点还是很多的,二叉搜索树,B-树,哈希表。一些基本操作还算是掌握,像插入删除操作都掌握的差不多了,但是转化成代码却不是很熟练,而且很多都用递归来完成,有些难理解,还需要时间来消化。还有就是LL,LR型调整不熟练,过一会就忘了解决哈希冲突也是偶尔会出错,还需要再练习
2.PTA实验作业(4分)
2.1 题目1:6-2 是否二叉搜索树
2.2 设计思路(伪代码或流程图)
定义一个静态变量min=-32768
if二叉树为空,则他是二叉搜索树,return true;
IsBST (T->Left);
if关键字>min min=关键字;
else return false;
IsBST(T->Right)
return true;
2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)
2.4 PTA提交列表说明。
- 错误代码:
bool IsBST ( BinTree T )
{
if (T== NULL)
return true;
if (T->left != NULL && T->left->data>T->data)
return false;
if (T->right != NULL && T->right->data < T->data)
return false;
if (! IsBST(T>left) || ! IsBST(T->right))
return false;
return true;
}
- 错误:一开始我的思路比较简单:对每一个节点,检测其值是否大于左子树节点,是否小于右子树节点同时满足这两个条件就是二叉搜索树。提交到pta那边在测试点:sample2 等价, NO和左右都是,但答案是NO错了;
- 解决办法:一开始我以为是漏了哪种情况没有考虑进去,后来发现是我的逻辑有问题。按照我的判断方法
3
/
2 5
/
1 4
上面那棵二叉树也被判定为二叉搜索树,因为每个检测都符合我的条件,但是我忽略了他的祖先节点导致错误,后来改了一下,用中序遍历就不会出现这个问题了。
2.1 题目2: 二叉搜索树中的最近公共祖先
2.2 设计思路(伪代码或流程图)
int find(Tree T,int number){
空树返回0
找到返回1
在左子树上
return find(T->Left,number);
在右子树上
return find(T->Right,number);
}
int find(Tree T,int u) {
T为空树 返回ERROR
if u,v都在左子树上;return LCA(T->Right,u,v);
if u,v都在右子树上;return LCA(T->Left,u,v);
if u,v一个在左子树上,一个在右子树上;return T->Key;
if u,v有一个在根上。 return T->Key;
}
2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)
2.4 PTA提交列表说明。
- 错误:一开始上面的这些情况基本上是想到一个写一个,但是提交以后就对了两个测试点
- 解决办法:后来按照伪代码所描述的修改了顺序,对的测试点多了,但是也并没有全对。
- 再后来自己加了一个函数查找u是否在树中,就对了
2.1 题目3:QQ帐户的申请与登陆
2.2 设计思路(伪代码或流程图)
int n,i;
char PassWord[30],IDNumber[20],control[2];
map<string,string>Q;
输入组数n
for( i=0 to i<n i++){
输出字符串control
control[0]=='N'为新用户时
申请账号密码
已存在该账号时输出ERROR: Exist;
否则输出New: OK
control[0]=='L' 旧用户登陆
输入账号密码
无该用户时,输出ERROR: Not Exis;
否则输出Login: OK
2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)
2.4 PTA提交列表说明。
3.截图本周题目集的PTA最后排名(3分)
3.1 PTA排名(截图带自己名字的排名)
3.2 我的总分:
115
4. 阅读代码(必做,1分)
- 线性探测法和二次探测法,链地址法实现哈希表的查找
https://blog.csdn.net/qq_35644234/article/details/68068293