温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

javascript有哪些搜索算法

发布时间:2021-11-12 13:41:28 来源:亿速云 阅读:144 作者:iii 栏目:编程语言

本篇内容主要讲解“javascript有哪些搜索算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript有哪些搜索算法”吧!

1、二分搜索,当一个集合被排序时,我们可以检查我们的检索值和中间项目。

并将我们想要的一半丢弃。事实上,我们的目标可以在对数时间和恒定空间中找到。

this.binarySerach= function(item){
this.quickSort(); //排序
 
var low= 0,
 
high= array.length-1,
 
mid,
 
element;
 
while( low<=high){
mid= Math.floor( (low+high)/2 );
 
element= array[mid];
 
if( element<item ){
low= mid+1;
 
} else if( element>item){
high= mid-1;
 
} else {
return mid;
 
}
 
}
 
return -1;
 
};

2、二叉搜索树,BST的创建发生在线时间和空间,但搜索需要一定的时间和空间。

另外一个排序集合的方法是生成一个二叉搜索树(BST)。对于BST的搜索效率和二分搜索一样高。用类似的方法,我们可以在每一次迭代中丢弃一半,我们知道不包含期望值的部分。实际上,另一个对集合进行排序的方法是按顺序对树木进行深度优先!

为了验证二叉树是否为BST,我们可以递归检查每一个左子项是否总小于根(最大可能),每一个右子项总大于每一个根(最小可能)。需要线性时间和一定的空间。

到此,相信大家对“javascript有哪些搜索算法”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI