C++二分查找在搜索引擎多文档求交的应用分析
本文实例讲述了C++二分查找在搜索引擎多文档求交的应用。分享给大家供大家参考。具体如下:
intsearch2(intarray[],intn,intv)
{
intleft,right,middle;
left=0,right=n-1;
while(left<=right)
{
middle=(left+right)/2;
if(array[middle]>v)
{
right=middle-1;
}
elseif(array[middle]<v)
{
left=middle+1;
}
else
{
returnmiddle;
}
}
return-1;
}
intsearch3(intarray[],intn,intv)
{
intleft,right,middle;
left=0,right=n;
while(left<right)
{
middle=(left+right)/2;
if(array[middle]>v)
{
right=middle;
}
elseif(array[middle]<v)
{
left=middle+1;
}
else
{
returnmiddle;
}
}
return-1;
}
二分查找的算法复杂度是log2n,是一种高效的查找。
在搜索中,会用到文档求交,比如用户的一个检索,从各个集群上网上吐数据,这些文档之间可能是存在交集的,并且提供的数据是有序的,怎么得到交集文档呢?
这个就可以使用二分查找,在多个有序的文档数组中,挑选一个最短的,然后一次从中选取一个元素,在其它数组中进行二分查找,这样就可以拿到交集文档。
希望本文所述对大家的C++程序设计有所帮助。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短