美文网首页
iOS中几种常见的查找算法的比较

iOS中几种常见的查找算法的比较

作者: LeafRead | 来源:发表于2016-07-13 16:38 被阅读439次

一、顺序查找  条件:无序或有序队列。

原理:按顺序比较每个元素,直到找到关键字为止。

时间复杂度:O(n)

二、二分查找(折半查找)  条件:有序数组

原理:查找过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;

如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。

如果在某一步骤数组为空,则代表找不到。

这种搜索算法每一次比较都使搜索范围缩小一半。

时间复杂度:O(logn)

三、哈希表(散列表)

条件:先创建哈希表(散列表)

原理:根据键值方式(Key value)进行查找,通过散列函数,定位数据元素。

时间复杂度:几乎是O(1),取决于产生冲突的多少。

相关文章

网友评论

      本文标题:iOS中几种常见的查找算法的比较

      本文链接:https://www.haomeiwen.com/subject/cezsjttx.html