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

自己建设网站怎么做中国行业数据分析网

自己建设网站怎么做,中国行业数据分析网,百度搜索广告价格,wordpress主题加密了目录二分找最左边二分找最右边综合应用(剑指offer)二分找最左边 核心思想: 先mid (lr)/2每次向左取整; 然后命中target的时候,右边界逼近到mid; 因为每次mid向左取整,mid命中target时l代替mid位置,则循环迭代最后会卡出重复数字最左侧的位置…

目录

    • 二分找最左边
    • 二分找最右边
    • 综合应用(剑指offer)

二分找最左边

核心思想: 先mid =(l+r)/2每次向左取整; 然后命中target的时候,右边界逼近到mid;

因为每次mid向左取整mid命中target时l代替mid位置,则循环迭代最后会卡出重复数字最左侧的位置!

可以用int arr[5] = 3 3 3 3 3 ; int target = 3; 这种极端的用例,来方便理解一下上述二分算法!

 //二分找k的最左侧位置while(l<r){mid =  (l+r)>>1; //mid向左取整if(arr[mid]>=target ) r = mid;//mid命中时右边界r代替mid位置(二分区间整体向左收缩了)else l = mid+1;}

寻找过程图示如下:

37_1


二分找最右边

核心思想: 先mid =(l+r+1)/2 每次向右取整; 然后命中target的时候,左边界逼近到mid;

因为每次mid向右取整mid命中target时l代替mid位置,则循环迭代最后会卡出重复数字最右侧的位置! 同上,不过多解释;

 //二分找target的最右侧位置while(l<r){mid =  (l+r+1)>>1; //mid向右取整if(arr[mid]<=target ) l = mid;//mid命中时左边界l代替mid位置(二分区间整体向右收缩了)else r = mid-1;}

不理解多理解即便,这个东西我也是理解了五六次,其实包含了一些边界的数学原理,可以从宏观的角度理解记忆,毕竟二分这个算法的变形,边界问题很多!


综合应用(剑指offer)

数字在升序数组中出现的次数

在这里插入图片描述

这道题要求O(logN)的时间复杂度,那肯定二分了!而且有序数组…这不是天然的二分有序条件吗;

题目解析

  • 据观察,重复的数字在有序数组中出现的位置一定是互相挨着的:

  • 那么我们只需要找到目标值k的最左侧下il标,和其最右侧下标ir,return ir-il+1; 即可!(当然,需要考虑一下k在数组中不存在的情况,这都是小问题啦)

怎么找最左侧和最右侧的k的下标,那就是上面设计的两种二分策略,需要掌握,常用!

实现代码

class Solution {
public:int GetNumberOfK(vector<int> data ,int k) {//二分找重复的最左 和 最右if(data.size()==0) return 0;int r = data.size() - 1;int l = 0;int mid;int il;int ir;//二分找k的最左侧位置while(l<r){mid =  (l+r)>>1; //向左取整if(data[mid]>=k) r = mid;//命中时右边界也向左逼近else l = mid+1;}if(data[l]!=k) return 0;//特殊情况,k不存在,返回0;il = l;//二分找k的最右侧位置l = 0;r = data.size() - 1;while(l<r){mid =  (l+r+1)>>1;//向右取整if(data[mid]<=k) l = mid;//命中时左边界也向右逼近else r = mid-1;}ir = l;return ir-il+1;}
};
http://www.hengruixuexiao.com/news/14350.html

相关文章:

  • 怎么做自己的淘宝客推广网站找网站公司制作网站
  • f006网站建设网络营销有哪些就业岗位
  • 外贸商城网站建设公司郑州百度搜索优化
  • 政务网站无障碍建设友情链接网站大全
  • 有哪些网站能免费建站怎么查权重查询
  • 受欢迎的做pc端网站电脑培训班零基础网课
  • 北京国税局网站官网入口盘搜搜
  • 网站目录怎么做301重定向外贸网络营销
  • 怎么让别人访问我建的网站学电脑在哪里报名
  • 重庆网站托管服务最近一周新闻
  • 政府网站建设工作大会讲话北京seo百度推广
  • 没有域名可以先做网站吗seo外链优化培训
  • 建设部网站执业资格线下推广宣传方式有哪些
  • 石家庄网站制作哪家好网站之家
  • 深圳专业网站建设制作微信公众号营销
  • 成都网站建设哪里好前端性能优化
  • 常州seo网络推广成都外贸seo
  • 专门做茶叶会的音乐网站引流app推广软件
  • 做公司网站联系公司seo实战优化
  • 男男做h的视频网站3d建模培训学校哪家好
  • 上海网站开发怎么做沈阳seo合作
  • 自动做网站的ai深圳龙岗区优化防控措施
  • 网站建设服务网站建设学做网站培训班要多少钱
  • 做百度联盟怎么才能创建多个网站百度收录量查询
  • 旅游网站开发的背景和意义奶茶网络营销策划方案
  • 网易博客搬家wordpressseo点击优化
  • 自己做一个购物网站乌海网站seo
  • o元做网站seo 工具推荐
  • 吉林省科瑞建设项目管理有限公司网站免费域名解析平台
  • 网站开发组合网上销售渠道