首页 > 其他 > 详细

截半查找

时间:2016-04-20 23:45:07      阅读:264      评论:0      收藏:0      [点我收藏+]

截半查找,跟顺序查找相似,但其效率更高,特别是数量越多的情况下,其基本形式为:

                 查找:

              int[] a = new int[8] { 4, 13, 22, 34, 41, 52, 64, 70 };

                输入要找的数:
              int find = Convert.ToInt32(Console.ReadLine());

                设定下标:
              int kaiShi = 0, jieShu = a.Length - 1, zhongJian;
              for (int i=0;i<7 ;i++ )
   {

                截半查找:
            zhongJian = (kaiShi + jieShu) / 2;
            if (a[zhongJian] == find)
        {
            Console.WriteLine("找到啦!是第{0}个数", a[i]);
            break;
        }

                如果没找到,在需要的一半数组中查找,每次排除一半,直到全部找完:
            else
     {
             if (a[zhongJian] < find)
         {
             kaiShi = zhongJian + 1;
         }
              else
         {
              jieShu = zhongJian - 1;
         }
                if (kaiShi > jieShu)
           {

                最后输出:
               Console.WriteLine("没找到");
               break;
           }
       }
   }

截半查找

原文:http://www.cnblogs.com/m-m-g-y0416/p/5414657.html

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