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

北京网站建设工作室如何网推

北京网站建设工作室,如何网推,城乡建设部统计网站,常州第一门户网文章目录 二分法概述二分 > value最左的位置二分 < value最右的位置局部最小值问题 二分法概述 什么是二分法呢&#xff1f;相信大家都有所了解&#xff0c;举个最经典的二分的例子。 ​ 给定一个整型有序数组&#xff0c;和一个值 v a l u e value value&#xff0c;如…

文章目录

  • 二分法概述
  • 二分 >= value最左的位置
  • 二分 <= value最右的位置
  • 局部最小值问题

二分法概述

    什么是二分法呢?相信大家都有所了解,举个最经典的二分的例子。

​ 给定一个整型有序数组,和一个值 v a l u e value value,如果 v a l u e value value在数组中,返回true否则返回false。由于数据状态的特殊性,并不需要遍历数组求解,只需要每次找到数组的中间位置mid,和value相比较,如果 > v a l u e > value >value则说明mid位置和mid位置右边的数据都不符合要求,故而更新 r = m i d − 1 r = mid - 1 r=mid1,反之则更新 l = m i d + 1 l = mid + 1 l=mid+1。这里给出两套边界条件,请自行筛选。

// 1	
public static boolean exist(int[] arr, int num) {if (sortedArr == null || sortedArr.length == 0) {return false;}int l = 0;int r = arr.length - 1;int mid = 0;// l == r 时结束,剩下最后一个数while (l < 4) { mid = l + ((r - l) >> 1); // 等价于 (l + r) / 2 ,防止溢出if (arr[mid] == num) {return true;} else if (arr[mid] >rnum) {r = mid - 1;} else {l = mid + 1;}}return arr[l] == num;
}
// 2
public static boolean exist(int[] arr, int num) {if (arr == null || arr.length == 0) {return false;}int l = 0;int r = arr.length - 1;int mid = 0;// L == R 时结束,剩下最后一个数while (l < r) {mid = l + ((r - l) >> 1);// 等价于 (l + r) / 2 ,防止溢出if (arr[mid] >= num) {r = mid;} else {l = mid + 1;}}return arr[l] == num;
}

    这个流程并不复杂,难得是边界条件的确定,这个就需要读者自行调试( D e b u g Debug Debug)理解。此处算法的时间复杂度为 O ( l o g N ) O(log N) O(logN),空间复杂度 O ( 1 ) O(1) O(1)

二分 >= value最左的位置

    自行完成,这里仅提供参考代码。

    public static int nearLeftIndex(int[] arr, int value) {if (arr == null || arr.length == 0) {return -1;}int l = 0;int r = arr.length - 1;int mid;while (l < r) {mid = (l + r) / 2;if (arr[mid] >= value) {r = mid;} else {l = mid + 1;}}return arr[l] < value ? -1 : l;}

二分 <= value最右的位置

    自行完成,这里仅提供参考代码。

 public static int nearRightIndex(int[] arr, int value) {if (arr == null || arr.length == 0) {return -1;}int l = 0;int r = arr.length - 1;int mid;while (l < r) {mid = l + r + 1 >> 1;if (arr[mid] <= value) {l = mid;} else {r = mid - 1;}}return arr[l] > value ? -1 : l;}

    相信做完这两道题你对二分的理解也更近了一步,那么接下来综合这两道练习题,请完成leetcode32题,这道题是对这两道练习题的综合,可以帮助你更好的掌握二分法,同时二分的写法也有多种,请选择适合自己的边界条件。

局部最小值问题

定义局部最小值:局部最小值是指其值严格小于左右相邻元素的值,给你一个整数数组 nums,找到局部最小值元素并返回其索引。数组可能包含多个局部最小值,在这种情况下,返回 任何一个局部最小值 所在位置即可。

  • 你可以认为 n u m s [ − 1 ] = + ∞ , n u m s [ n ] = + ∞ nums[-1] = +∞,nums[n] = +∞ nums[1]=+nums[n]=+

  • 你必须实现时间复杂度为 O(log n) 的算法来解决此问题。

  • n u m s [ i ] ! = n u m s [ i + 1 ] nums[i] != nums[i + 1] nums[i]!=nums[i+1]

  • n n n为数组长度

    此题由于数据状况特殊,题目局部最小值的定义特殊,所以我们可以使用二分法进行求解。首先我们要先知道 n u m s [ − 1 ] = + ∞ , n u m s [ n ] = + ∞ nums[-1] = +∞,nums[n] = +∞ nums[1]=+nums[n]=+,也就是数组左侧是下降的,并且右侧也是下降(U型),而且相邻元素之间不相等,这就很特殊了,保证了数组之中一定有局部最小值,并且可以二分。如果 n u m s [ m i d ] < n u m s [ m i d + 1 ] nums[mid] < nums[mid + 1] nums[mid]<nums[mid+1]则左边会存在局部最小值去掉右边( r = m i d r = mid r=mid),如果 n u m s [ m i d ] > n u m s [ m i d + 1 ] nums[mid] > nums[mid + 1] nums[mid]>nums[mid+1]则右边会存在局部最小值去掉左边( l = m i d − 1 l = mid - 1 l=mid1)。

  public static int getLessIndex(int[] arr) {if (arr == null || arr.length == 0) {return -1; // no exist}if (arr.length == 1 || arr[0] < arr[1]) {return 0;}if (arr[arr.length - 1] < arr[arr.length - 2]) {return arr.length - 1;}int l = 1;int r = arr.length - 2;int mid = 0;while (l < r) {mid = l + r >> 1;if (arr[mid] >= arr[mid + 1]) {l = mid + 1;} else {r = mid;}}return l;}

    请完成162. 寻找峰值,如果本篇文章对你有帮助,请点赞、评论、转发,你的支持是我创作的动力!!!

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

相关文章:

  • 便宜网站建设多少钱网站开发与管理内容
  • 新西兰网站开发专业域名对网站的好处
  • 网站建设一条龙源码h5网站建设模板下载
  • 企业建网站的费用建筑设计网站issuu
  • 沧州网站建设制作设计优化网站建设需要每年交钱吗
  • 青岛网站建设运营推广苏州相城网站建设
  • 达州达县网站建设深圳百度网站优化
  • 做投票网站教程建设工程人员锁定网站
  • 安微省建设厅田网站大连装修公司排名榜
  • 广州网站定制开发方案企业网站建设实训总结
  • 上海建设工程安全质量监督总站网站设计作品展示网站
  • 顶尖的网站建设长沙找工作哪个网站好
  • 自适应式网站模板网站视频接口 怎么做
  • 当地建设厅网站中国最著名的40个建筑
  • 商务网站建设体会长沙网站制作费用
  • 做网站最下面写什么软件企业高管培训课程有哪些
  • 现在企业做门户网站云南网招聘
  • 苏州定制型网站建设wordpress网站分享朋友圈缩略图
  • 网站建设制作团队网络营销推广的力度
  • 网站开发软硬件条件广告推广有哪些平台
  • 重庆建设网站哪家专业请人做网站需要多少钱
  • 建设工程网站贴吧网站页面做
  • 怎么创建自己的网站平台站酷网络
  • 景区外文网站建设怎么做网站管理
  • 上海保洁服务网站建设网站建设包含哪些建设阶段
  • 高校网站建设目的百度号码认证平台取消标记
  • 网站后台不能上传网站建设毕业答辩ppt模板
  • 提升网站响应时间张雪峰最不建议上的专业
  • 江阴企业网站制作修改wordpress分类顺序
  • 建设网站用什么语言好做网站可以申请专利吗