二分法查找

二分法是一个快速查找的简单算法,当然它要求查找的数组是有序的,看起来好像比暴力要麻烦一些,但是即便加上排序,logn+logn也要比n小,因此在即便加上排序,也要比暴力的时间效率高很多(小白见解,不对请指正,不胜感激),例题代码如下:

 1 #include "stdafx.h"
 2 #include<cstdlib>
 3 #include <iostream>
 4 #include <algorithm>
 5 //首先明白原理和能写出来还是有很多差距的,其次对于C输入数组,数组作为参数传递,指针的应用等等都还需要慢慢去理解...
 6 int DichotomySearch(int Array[],int k,int n)
 7 {
 8     int min = 1,max =n;
 9     int mid;
10     //二分查找核心代码
11     while(min <= max)
12     {
13         mid = (min + max) / 2;
14         if(k < Array[mid])
15         {
16             max = mid - 1;
17         }
18         else if(k > Array[mid])
19         {
20             min = mid + 1;
21         }
22         else
23         {
24             return 1;
25         }
26     }
27     return 0;
28 }
29 int _tmain(int argc, _TCHAR* argv[])
30 {
31     int Array[40000];
32     int k;
33     int n;
34     printf("请输入将要输入有序数组的长度:");
35     scanf("%d",&n);
36     printf("请输入一个有序数组:");
37     for(int i = 1; i <= n; i++)//当输入长度不确定时可以用EOF
38     {
39         scanf("%d",&Array[i]);
40     }
41     printf("请输入一个数字:");
42     scanf("%d",&k);
43     //必须是有序数组
44     if(DichotomySearch(Array,k,n))
45         printf("%d在数组中出现过",k);
46     else
47         printf("%d在数组中未出现",k);
48     system("pause");
49     return 0;
50 }

 

 

转载于:https://www.cnblogs.com/baikequanshu/p/3390775.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值