二分法解释

本文详细介绍了二分法,一种在有序数组中通过每次比较缩小搜索范围的查找算法。通过实例演示了如何使用二分法解决蒜头君查询数组的问题,并讨论了其在简化问题和提高效率上的作用。适合理解和应用在大规模数据搜索场景。
摘要由CSDN通过智能技术生成

二分法:也称折半搜索对数搜索,是一种在有序数组中查找某一特定元素的搜索算法。搜索过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜索过程结束;如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。如果在某一步骤数组为空,则代表找不到。这种搜索算法每一次比较都使搜索范围缩小一半。

这种方法可以将复杂问题简单化,缩短时间。

例:

蒜头君手上有个长度为 n 的数组 A。由于数组实在太大了,所以蒜头君也不知道数组里面有什么数字,所以蒜头君会经常询问整数 x 是否在数组 A 中。

输入格式
第一行输入两个整数 n 和 m,分别表示数组的长度和查询的次数。

接下来一行有 n 个整数 a1.

接下来 m 行,每行有 1 个整数 x,表示蒜头君询问的整数。

输出格式
对于每次查询,如果可以找到,输出"YES",否则输出"NO"。

数据范围
1≤n,m≤10的5次方,0≤x≤10的6次方。

以下展示二分法的一段。

for(i=0;i<m;i++)//
    {
        left = 0;
        right = n - 1;
          while(right >= left)
          {
              mid = (right + left)/2;//找出数组中中间的数
              if(str1[mid] < str2[i] )//当数组中间的那个数小于输入x的值
              {
                left = mid + 1;       //缩小范围
              }
              else if(str1[mid] > str2[i])//当数组中间的那个数大于输入x的值
              {
                right = mid - 1;//缩小范围
              }
              else if(str1[mid] == str2[i])//当数组中的数有数符合x的值时跳出
              {
                  judge = 1;//标记符合,减少时间
                  printf("YES\n");
                  break;
              }
           }

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值