重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
递归,分而治之,其思想是将n个元素分成大致相同数目的两半,取a[n/2]与要找到的X进行比较,如果X=a[n/2],则找到X,算法结束。如果X<A[n/2],那么我们只需要继续在数组a的左半部分搜索X(假设数组元素按升序排列)。如果X>A[n/2],那么我们只需要在数组a的右半部分继续搜索X。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:主机域名、网络空间、营销软件、网站建设、汨罗网站维护、网站推广。C语言中怎样利用折半查找法(二分查找法)找到数列中的一个数?根据需要,使用二分法在指定的数组中找到指定的数字。代码如下:#include<stdio。H>//在长度为len的数组a中查找n,如果找到则返回数组下标,并返回-1intsearch(inta[]intlen,INTN){intindex=-1intleft=0,right=len,mid=(left)}right)/2while(left<=right){if(n==a[mid]){index=midbreak}elseif(n>a[mid]){left=mid1mid=(leftright)/2}else{right=mid-1mid=(leftright)/2}returnindex}intmain(){intarray[]={5、8、13、17、23、25、29、50、53}//数组intlength=9//数组长度intaim=17//查找目标//输出搜索结果,search17array[]:3printf(“search%dinarray[:%d\n”,aim,search(array,length,aim))return0}