当前位置: 首页 > news >正文

国外做旅游攻略的网站好免费产品推广软件

国外做旅游攻略的网站好,免费产品推广软件,企业网络推广平台有哪些,侯马做网站决定我们成为什么样人的,不是我们的能力,而是我们的选择。——《哈利波特与密室》二分查找是查找算法里面是很优秀的一个算法,特别是在有序的数组中,这种算法思想体现的淋漓尽致。一.题目描述及其要求请实现无重复数字的升序数组的…

决定我们成为什么样人的,不是我们的能力,而是我们的选择。——《哈利·波特与密室》


二分查找是查找算法里面是很优秀的一个算法,特别是在有序的数组中,这种算法思想体现的淋漓尽致。

一.题目描述及其要求

请实现无重复数字的升序数组的二分查找:

给定一个 元素升序的、无重复数字的整型数组 arr和一个目标值 target ,写一个函数搜索 arr中的 target,如果目标值存在返回下标(下标从 0 开始),否则返回 -1.

示例一:

输入:[-1,0,3,4,6,10,13,14],13
返回值:6
说明:13 出现在arr中并且下标为 6 

示例二:

输入:[],3
返回值:-1
说明:arr为空,返回-1  

示例三:

输入:[-1,0,3,4,6,10,13,14],2
返回值:-1
说明:2 不存在arr中因此返回 -1 

二.分治思想

分治即“分而治之”,“分”指的是将一个大而复杂的问题划分成多个性质相同但是规模更小的子问题子问题继续按照这样划分直到问题可以被轻易解决“治”指的是将子问题单独进行处理。经过分治后的子问题,需要将解进行合并才能得到原问题的解,因此整个分治过程经常用递归来实现。

1.逐个遍历思路:

本来我们可以遍历数组直接查找,每次检查当前元素是不是要找的值。

for(int i = 0; i <length; i++)if(arr[i] == target)return i;

2.逐个遍历出现的问题

但是这样这个有序的数组我们就没有完全利用起来。

我们想想,若是目标值比较小,肯定在前半区间,若是目标值比较大,肯定在后半区间,怎么评价大小?我们可以用中点值作为一个标杆,将整个数组分为两个区间,目标值与中点值比较就能知道它会在哪个区间,这就是分治的思维。

三分治思想具体做法:

  • step 1:从数组首尾开始,每次取中点值。

  • step 2:如果中间值等于目标即找到了,可返回下标,如果中点值大于目标,说明中点以后的都大于目标,因此目标在中点左半区间,如果中点值小于目标,则相反。

  • step 3:根据比较进入对应的区间,直到区间左右端相遇,意味着没有找到

代码实现:

int search(int*arr, int length, int target ) {if(length == 0) return -1;int left=0, right=length-1;while(left<=right) {int mid = left+(right-left)/2;if(arr[mid]==target) return mid;if(arr[mid]<target) left=mid+1;if(arr[mid]>target) right=mid-1;}return -1;
}

ps:int mid = left+(right-left)/2;与int mid=(left+right)/2是一样的,但是选择前者更安全,因为后者两个整数相加数据过于庞大可能会出现数据溢出的情况,所以采用前者更加可靠。

也可以这样写:mid = left+(right-left >> 1); +-大于位移运算的优先级 左移*2

本算法到这,其实二分查找可以分为几种情况来讨论,这里提供一种比较好理解的方案,具体算法大家可以参考相应资料自了解,大家加油。。。。。最近在做算法题目可以关注我,点个赞,有问题可以一起讨论。以后的几篇文章都讲解算法的题目。

http://www.yayakq.cn/news/611698/

相关文章:

  • html5微信网站模板如何做导购网站
  • 南京网站开发南京乐识行广州网络推广公司有哪些
  • 免费企业网站建设免费怎么制作网站建设
  • 公司网站建设费用入账安塞网站建设
  • 岱山县建设网站做网站咨询
  • 那些网站可以做推广专门做肥料外贸的网站
  • 有哪些做的好的汽配零配件网站内部网站建设的步骤过程
  • 深圳最好的网站开发公司wordpress minty 2.6
  • 哪里可做网站重庆石柱网站设计公司
  • 网站建设标题免费提供网站
  • 平面设计专业网站律所网站建设管理制度
  • 西安网站建设itcandy宁波市建设局
  • 遵义网站seo查销售数据的网站
  • 太原网站搜索排名免费的app源码网
  • 湖南省水利水电建设工程学校网站宣城网站建设jidela
  • 360搜索怎么做网站自然优化做网站用什么电脑好
  • 软文发稿网站射阳做网站公司
  • 判断网站网站建设服务费是否无形资产
  • 青岛网站设计 网站建设潭州教育网站开发
  • php与dw怎么做校园网站iis网站出乱码
  • 视频营销网站老铁推荐个2021网站好吗
  • 威海相亲网站广西网站建设与规划
  • wordpress建站教程百科泰安住房和城乡建设厅网站
  • 电商网站模块有哪些深圳高端网站建设收费
  • 怎样做门户网站青海制作网站
  • 回龙观网站建设wordpress 上传失败
  • 网站建设这一行业怎样泰安集团网站建设
  • 湖南手机网站建设标志设计公司成都
  • 哪些网站做的比较好的网上整合营销
  • 广州网站优化专家百度统计怎么用