如果数组元素已经排过序(升序),那我们搜索某个元素就不必遍历整个数组了。在下面给出的算法代码中,到任何一点,假设当前的arr[i]值大于搜索的值data,就可以停止搜索了。

#include<stdio.h>

// a function to search "data" in an array "arr" of size "size"
// returns 1 if the element is present else 0
int orderedLinearSearch(int arr[], int size, int data)
{
int found_flag = 0; int i;
for(i=0;i<size;i++)
{
//loop through the entire array and search for the element
if(arr[i] == data)
{
// if the element is found, we change the flag and break the loop
found_flag = 1;
break;
}
// here is an additional check
else if(arr[i] > data)
break;
} return found_flag;
} //driver program to test the function
int main(void)
{
int arr[10] = {2, 6, 4, 10, 8, 1, 9, 5, 3, 7}; int to_search = 5; if(orderedLinearSearch(arr,10,to_search))
printf("FOUND");
else
printf("NOT FOUND"); return 0;
}

算法的时间复杂度为O(n)。这是因为在最差的情况下我们仍然要搜索整个数组。虽然增长率和无序线性搜索一样,但在平均情况下减少了复杂度。

空间复杂度为O(1)。

注:我们还可以增加索引增加的速率来提高算法速度。这样会减少算法中比较的次数。但这样会有几率跳过所要搜索的数据。

最新文章

  1. 【转】Java面试题全集2.2(下)
  2. Unity3D 材质球设置参数无效果的解决方法
  3. python 线程使用
  4. CSS3实用方法小记 2016.03.16
  5. 异曲同工的AWK语句,学习
  6. 腾讯webqq最新password加密算法,hash算法
  7. shell程序设计(转)
  8. c语言_头文件
  9. PS各个工具的字母快捷键和英…
  10. 利用Python循环(包括while&amp;for)各种打印九九乘法表
  11. mpeg文件格式分析
  12. Chrome 浏览器数据无法同步,google账号登录失败,提示 Request canceled
  13. BZOJ5361[Lydsy1805月赛]对称数——主席树+随机化
  14. HashMap 与 ConcurrentHashMap 在初始化不同大小容量时,实际分配的空间情况
  15. MySQL大表DROP删除小技巧(转)
  16. linux centos6.5 php5.6 安装PHPUnit 5.2.9 (转)
  17. 【轻松前端之旅】&lt;!DOCTYPE&gt;标签
  18. 796. Rotate String
  19. 【bzoj1030】 JSOI2007—文本生成器
  20. C/S模式下的打印方法

热门文章

  1. WIN8共享文件 详细设置
  2. Javascript或jQuery方法产生任意随机整数
  3. Linux shell编程02 shell程序的执行 及文件权限
  4. pyqt 同时勾选多个items(网友提供学习)
  5. c++之 printf 打印内容
  6. (3)选择元素——(6)属性选择器(Attribute selectors)
  7. vs连接mysql出错解决方法
  8. 解决Xcode6.4安装插件后插件不能使用的问题
  9. 8.0 BOM对象
  10. textView富文本点击事件