静态查找中哨兵的作用
时间:2011-07-23
来源:互联网
数据结构第9章中顺序查找ADT如下:
int Search_Seq(SSTable,KeyType key)
{
ST.elem[0].key = key; //哨兵
for(i=ST.length; !EQ(ST.elem[i].key,key);--i) //从后往前找
return i;
}
书中说到,查找之前先对ST.elem[0]的关键字赋值key,目的在于免去查找过程中每一步都要检测整个表是否查找完毕。
这句话如何理解?每一次查找的时候不还得挨着找一遍吗?
不太理解这句话。烦请高手指导。
int Search_Seq(SSTable,KeyType key)
{
ST.elem[0].key = key; //哨兵
for(i=ST.length; !EQ(ST.elem[i].key,key);--i) //从后往前找
return i;
}
书中说到,查找之前先对ST.elem[0]的关键字赋值key,目的在于免去查找过程中每一步都要检测整个表是否查找完毕。
这句话如何理解?每一次查找的时候不还得挨着找一遍吗?
不太理解这句话。烦请高手指导。
作者: FirstMrWu 发布时间: 2011-07-23
你想想:当目标在数组里面的时候,返回的是他的下标,也就是非0值,当都找不到的时候,但是由于有这句话ST.elem[0].key = key,所以查找到头的时候也找到了,只是这是人为的,返回0。所以,根据返回值可以确定。
作者: justlovetao 发布时间: 2011-07-23
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28