随笔 - 384  文章 - 0  评论 - 0  阅读 - 13万

力扣278(java&python)-第一个错误的版本(简单)

题目:

你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。

假设你有 n 个版本 [1, 2, ..., n],你想找出导致之后所有版本出错的第一个错误的版本。

你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单元测试中出错。实现一个函数来查找第一个错误的版本。你应该尽量减少对调用 API 的次数。

 
示例 1:

输入:n = 5, bad = 4
输出:4
解释:
调用 isBadVersion(3) -> false
调用 isBadVersion(5) -> true
调用 isBadVersion(4) -> true
所以,4 是第一个错误的版本。
示例 2:

输入:n = 1, bad = 1
输出:1
 

提示:

  • 1 <= bad <= n <= 231 - 1

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/first-bad-version
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

【二分查找】

题目中要求要尽量减少对调用 API 的次数,所以要尽可能的缩小检索的范围,这样就可以将调用检查接口的次数降到最低。且题目中提到错误的版本之后的所有版本都是错的。这样就可以利用二分查找法:

  • 设置左右边界并初始化left = 1,right = n,循环的条件是:left < right,mid = left + (right - left) / 2;
  • 如果该版本是正确版本,那么第一个错误版本一定在当前mid的右侧,答案一定在[mid+1, right]范围内,即left = mid + 1;
  • 如果该版本是错误版本,那么第一个错误版本有可能为当前版本或者当前版本之前的版本,答案一定在[left, mid]范围内,即right = mid。
  • 最后一定有:left == right,区间为一个点,返回left或者right都可以。

java代码:

复制代码
 1 /* The isBadVersion API is defined in the parent class VersionControl.
 2       boolean isBadVersion(int version); */
 3 
 4 public class Solution extends VersionControl {
 5     public int firstBadVersion(int n) {
 6         int left = 1, right = n;
 7         while(left < right){
 8             int mid = left + (right - left) / 2;
 9             //true:是错误版本,有可能mid就是答案
10             if(isBadVersion(mid)){
11                 right = mid;
12             }else{
13                 //false:正确版本,往后移
14                 left = mid + 1;
15             }
16         }
17         return left;
18     }
19 }
复制代码

 python3版本:

复制代码
 1 # The isBadVersion API is already defined for you.
 2 # def isBadVersion(version: int) -> bool:
 3 
 4 class Solution:
 5     def firstBadVersion(self, n: int) -> int:
 6         left, right = 1, n
 7         while left < right:
 8             mid = left + (right - left) // 2
 9             if isBadVersion(mid):
10                 right = mid
11             else:
12                 left = mid + 1
13         return right
复制代码

posted on   我不想一直当菜鸟  阅读(30)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
历史上的今天:
2021-11-14 4.CSS层次选择器
2021-11-14 3.CSS三种基本选择器
2021-11-14 19_非单文件名组件中VueComponent构造函数&重要的内置关系
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示