首页 > 其他 > 详细

折半查找法

时间:2015-10-13 01:49:28      阅读:247      评论:0      收藏:0      [点我收藏+]
#include<stdio.h>
int bin_search(int arr[], int start, int end, int search)
{
         while (start <= end)
         {
                int mid = (start + end) / 2;
                if (arr[mid] > search)
                {
                    end = mid - 1;

                }
                else if (arr[mid] < search)
                {
                    start = mid + 1;
                }
                else
                {
                    return mid;
                }
         }
         return -1;
}
int main()
{
         int arr[10] = {0,1,2,3,4,5,6,7,8,9};
	 int m=0,ret=0;
	 printf("输入所需查找的数m:");
         scanf("%d",&m);
         ret = bin_search(arr, 0, sizeof(arr) / sizeof(arr[0])-1, m);
         if (ret == -1)
         {
               printf("查无此数!\n");
         }
         else
         {
               printf("该数存在:%d\n",arr[ret]);
         }
         return 0;
}


本文出自 “花开彼岸” 博客,请务必保留此出处http://zxtong.blog.51cto.com/10697148/1702241

折半查找法

原文:http://zxtong.blog.51cto.com/10697148/1702241

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!