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

整站wordpress下载南宁seo多少钱报价

整站wordpress下载,南宁seo多少钱报价,百度提交链接多久会被收录,温建设文件发布在哪个网站目录 一、概念 二、思路 三、边界问题 一、概念 在一本书中查找某一页,我们总是倾向于先翻到整本书的中间,然后根据当前页数判断我们想要找的页在当前页的左半本中还是右半本中,接着继续翻到剩下半本书的中间...... 这就是二分查找思想在…

目录

一、概念

二、思路

三、边界问题


一、概念

在一本书中查找某一页,我们总是倾向于先翻到整本书的中间,然后根据当前页数判断我们想要找的页在当前页的左半本中还是右半本中,接着继续翻到剩下半本书的中间......

这就是二分查找思想在现实中的应用,但为什么这种方法能够比较快的查找到我们想要的页数?这是因为书中的页数是有序的,通过当前页数与目标页数的比较,我们能够确保目标页在当前页的左侧还是右侧


二、思路

二分查找的时间复杂度为O(logN),但是只适用于在有二分性质的序列中进行查找

二分性质:即我们可以自定义一个性质,让区间的左半部分都不满足,右半部分都满足 

最朴素的场景:有序的数组

  • 以下面的有序数组为例,首先用l和r维护我们需要二分的区间

  • 取区间的中点,判断中点值与我们的目标的大小关系

注意,如果区间元素的个数是奇数,那么只有一个中点;但如果元素个数是偶数,那么就会存在两个中点,例如上面的5和7都是中点

此处我们只讨论比较特殊的情况,即有偶数个元素的情况

对于该情况,我们可以选择每次取区间的左中点或右中点

取左中点:

int mid = (l + r) / 2;
int mid = l + (r - l) / 2; //防溢出

如果采用上面(l + r) / 2的方式来取左中点,如果l和r的值过大则有数值溢出的风险,因此建议使用第二个的方式

取右中点:

int mid = (l + r + 1) / 2;
int mid = l + (r - l + 1) / 2; //防溢出

由于除法向下取整,因此如果元素个数为奇数,不论是以取左中点的方式还是取右中点的方式,我们都能够取到中点,例如:

下面以偶数个元素为例

  • 以取左中点为例,我们取左中点值5

  • 5比8小,且我们的数组是升序的,则要查找的目标在右半部分

  • 重复上述步骤

要理解二分查找的思路并不难,有难度的地方在于其边界问题的处理


三、边界问题

以取左中点为例,我们先来看正确的代码

int Binary_Search(int* a, int sz, int x) //假设数组升序
{int l = 0, r = sz - 1; //区间左右边界while(l < r){int mid = l + (r - l) / 2; //取左中点if(a[mid] > x) //中点值比x大:目标在左半部分r = mid;else if(a[mid] < x) //中点值比x小:目标在右半部分l = mid + 1; else //相等return mid; //返回下标}//走出循环,说明l==r,判断此时位置是否与x相等if(a[l] == x)return l;return -1;
}

可以看到,当中点值比x大时,目标在左半部分,r移动到原来mid的位置;但当中点值比x小时,目标在右半部分,而l却移动到了mid+1的位置。为什么不是和r一样移动到mid?

我们看一个最简单的例子

只有两个元素,中点mid与l位置重合,且目标为2大于中点值1,此时l需要移动到mid+1的位置

可以正常找到我们的目标

但如果上一步中,l移动到mid的位置会怎么样呢?l和mid的位置本来就是重合的,移动过后位置没有改变,导致死循环

这说明,不论是取左中点还是右中点,一旦边界问题没有处理好,那么就会导致死循环

取右中点的代码:

int Binary_Search(int* a, int sz, int x) //假设数组升序
{int l = 0, r = sz - 1; //区间左右边界while(l < r){int mid = l + (r - l + 1) / 2; //取右中点if(a[mid] > x) //中点值比x大:目标在左半部分r = mid - 1;else if(a[mid] < x) //中点值比x小:目标在右半部分l = mid; else //相等return mid; //返回下标}//走出循环,说明l==r,判断此时位置是否与x相等if(a[l] == x)return l;return -1;
}

修改对应取中点的方式,并修改r和l的移动方式即可,原理和上面是相同的

如果不想考虑边界情况,则还有一种方式:

int Binary_Search(int* a, int sz, int x) //假设数组升序
{int l = 0, r = sz - 1; //区间左右边界while(l <= r){int mid = l + (r - l) / 2; //取左中点//int mid = l + (r - l + 1) / 2; //取右中点if(a[mid] > x) //中点值比x大:目标在左半部分r = mid - 1;else if(a[mid] < x) //中点值比x小:目标在右半部分l = mid + 1; else //相等return mid; //返回下标}return -1;
}

在这种方式下,r和l移动后都不会与原来的mid位置重合

完.

http://www.tj-hxxt.cn/news/127160.html

相关文章:

  • 安阳哪里有学做网站的学校福州网站优化公司
  • 外包和劳务派遣哪个好淘宝seo搜索引擎原理
  • 什么网站可以做字体效果网络推广服务合同
  • 做销售网站多少钱今天百度数据
  • wordpress特定文章小工具7个湖北seo网站推广策略
  • 现在最常用网站开发工具如何成为app推广代理
  • 来广营做网站软文广告是什么
  • 个人网站建设教程外链群发软件
  • 上海浦东新区做网站搜索热度查询
  • 苏州市吴江区建设局网站网络营销好找工作吗
  • 免费网站建设必找186一6159一6345宁波seo网络推广选哪家
  • 柳州建设网站经济适用房表格百度一下官方网址
  • 有域名有空间如何做网站唐山seo优化
  • 淄博市淄川疫情最新情况seo顾问赚钱吗
  • 中文 wordpress 主题seo公司培训课程
  • 做网盘搜索网站合法吗加拿大搜索引擎
  • 做电影资源网站服务器怎么选百度一下网页入口
  • 个人网站制作说明网络营销的真实案例分析
  • 金华网站制作价格网站排名seo软件
  • 做淘宝门头的网站百度指数查询
  • 专业的做网站软件qq群引流推广软件
  • 呼和浩特网站建设哪家最便宜浙江seo博客
  • 邢台营销型网站建设网站优化seo怎么做
  • 投诉网站怎么做seo综合查询什么意思
  • 企业微信开发者工具游戏优化大师官网
  • 个人备案的网站可以做商城吗东莞优化怎么做seo
  • 网站开发工程师岗位职责seo还有哪些方面的优化
  • 网络营销网站建设诊断报告深圳关键词seo
  • 公司网站开发费用怎么做账国际新闻最新消息10条
  • 中铁中基建设集团网站seo基础