谁能解释下C语言哨兵的原理,为什么加入哨兵后就能判断是否越界?最好用代码举例解释!

如题所述

所谓“哨兵”就是用一个特殊值来作为数组的边界,使用“哨兵”可以少用一条判断语句,所以可以提高程序的效率。
比如从整数数组arr中,查找有没有整数num。
应用:假设一个乱序数组,需要查找一个元素是否在该数组中,这时需要用到顺序查找,也就是遍历数组。
一般情况下我们会写下如下代码:
int Sequential_Search(int *a,int n,int key)
{
//数组从1开始
int i;
for(int i=1;i<=n;i++)
{
if(a[i]==key)
return i;
}
return 0;//查找失败
}
有的数据结构书上,会运用哨兵元素,改成这样的代码:
int Sequential_Search2(int *a int n,int key)
{
int i=0;
a[0]=key;//哨兵
i=n;
while(a[i]!=key)
{
i--;
}
return i;//返回0就是查找失败
}追问

还是不太明白哦,为什么加入哨兵了就能少用一句判断语句呢?

追答

没用“哨兵”,两条判断:i<=n;和if(a[i]==key)

用了“哨兵”,一条判断:while(a[i]!=key)

温馨提示:答案为网友推荐,仅供参考
相似回答