静态查找中哨兵的作用
时间: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版激活秘钥/序列号/激活码推荐 附激活工具 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具阅读:74 
-   如何安装mysql8.0 如何安装mysql8.0阅读:31 
-   Word快速设置标题样式步骤详解 Word快速设置标题样式步骤详解阅读:28 
-   20+道必知必会的Vue面试题(附答案解析) 20+道必知必会的Vue面试题(附答案解析)阅读:37 
-   HTML如何制作表单 HTML如何制作表单阅读:22 
-   百词斩可以改天数吗?当然可以,4个步骤轻松修改天数! 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!阅读:31 
-   ET文件格式和XLS格式文件之间如何转化? ET文件格式和XLS格式文件之间如何转化?阅读:24 
-   react和vue的区别及优缺点是什么 react和vue的区别及优缺点是什么阅读:121 
-   支付宝人脸识别如何关闭? 支付宝人脸识别如何关闭?阅读:21 
-   腾讯微云怎么修改照片或视频备份路径? 腾讯微云怎么修改照片或视频备份路径?阅读:28 















