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

二分算法(模板)

例题1:

704. 二分查找 - 力扣(LeetCode)

算法原理:(二分)

通过遍历也可以通过,但是二分更优且数据量越大越能体现。

二分思路:

1.mid1 =  (left + right)/2 与 mid2 = right + (right - left)/2区别。

如果不考虑数据范围: (left + right)/2  = right + (right - left)/2,但越界就不一样了。

mid1 =  (left + right)/2 :可能越界

mid2 = left+ (right - left)/2 : 可以防止越界

2.mid1 = (right + left)/2 与 mid2 = (right + left + 1)/2区别。

(right + left)/2  : 向下取整

(right + left + 1)/2 :向上取整

举个例子: right = 3,left = 4,(right + left)/2  = 3,(right + left + 1)/2 = 4;

                   right = 2,left = 4,(right + left)/2  = 3,(right + left + 1)/2 = 3;

这里不会严格用数学方式去证明,那样太花时间了,感兴趣的话网上搜搜,我们直接给出结论,当right + left 结果为偶数时,mid1 与 mid2 是没有区别的,但结果为奇数时就会相差1,不要小看了这一点区别,不注意这里,就很有可能写出死循环,具体我们在下面例题里体现。

这里不能通过调整上下取整的方式来避免死循环。但是可以通过增加一行代码来弄

(       if(left == right && nums[left] != target) break;      )

代码:

//暴力可以过😯public int search(int[] nums, int target) {int n = nums.length;for(int i = 0;i < n;i++){if(nums[i] > target){break;}if(nums[i] == target) return i;}return -1;}
     //二分public int search(int[] nums, int target) {int left = 0;int right = nums.length - 1;while(left <= right){int mid = left + (right - left)/2;if(nums[mid] < target){left = mid+1;}else if(nums[mid] ==target){return mid;}else {right = mid-1;}}return -1;}
//二分,调整后public int search(int[] nums, int target) {int left = 0;int right = nums.length - 1;while(left <= right){int mid = left + (right - left)/2;if(nums[mid] < target){left = mid+1;}else if(nums[mid] ==target){return mid;}else {right = mid;}if(left == right && nums[left] != target) break; }return -1;}

 

通过上面两幅幅图我们就可以感受到上,下取整差1,如果调整不好便会出现死循环。这里只列举了向下取整,避免死循环情况。还有一种是向上取整,避免死循环情况。(再往下的例题就不会,所这么多了。) 

如下例题都是可以利用二分解决的,这里就提一点,二分的使用场景并不一定非要整个序列有序,而是依据你的需求,巧妙的去使用它。

例题2:

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)

例题3:

162. 寻找峰值 - 力扣(LeetCode)

例题4:

153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)

http://www.lryc.cn/news/622347.html

相关文章:

  • 数据结构与算法p4
  • 什么是ai智能?AI的九年飞跃史:从AlphaGo到Agent智能体
  • 项目管理工具
  • 图说据小学常识证伪数学公理——平面公理是将无穷多各异平面误为同一面的“井底蛙”误区
  • LINUX服务运行CPU平均负载率异常高,CPU占用高
  • ollama大模型
  • fpga高速接口汇总整理
  • 让数据可视化更简单:Embedding Atlas使用指南
  • k8s环境使用Operator部署Seaweedfs集群(一)
  • 【反序列化基本介绍】
  • 48Days-Day19 | ISBN号,kotori和迷宫,矩阵最长递增路径
  • Point-LIO技术文档中文翻译解析
  • 文章数据发布到苹果CMS(MacCMS)网站技巧
  • ETH持续上涨推动DEX热潮,交易活跃度飙升的XBIT表现强势出圈
  • 图论Day3学习心得
  • 【机器学习】核心分类及详细介绍
  • 开疆智能ModbusTCP转Ethernet网关连接FBOX串口服务器配置案例
  • 【iOS】多线程原理
  • 昇腾AI自学Day1-- 深度学习基础工具与数学
  • C语言基础08——文件的输入与输出
  • git clone https://gh.llkk.cc/
  • 什么才是真正的白盒测试?
  • 高并发接口性能优化实战:从200ms到20ms的蜕变之路
  • Python正则表达式处理Unicode字符完全指南:从基础到高级实战
  • Python工具箱系列(六十四)
  • Java Lambda表达式是什么,怎么用
  • JavaWeb开发_Day12
  • 研学智得AI-知网推出的AI学术文献阅读工具
  • OpenCV---morphologyEx形态学操作
  • Java中MybatisPlus使用多线程多数据源失效