zoukankan      html  css  js  c++  java
  • 刷题-力扣-278. 第一个错误的版本

    278. 第一个错误的版本

    题目链接

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

    题目描述

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

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

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

    示例:

    给定 n = 5,并且 version = 4 是第一个错误的版本。
    
    调用 isBadVersion(3) -> false
    调用 isBadVersion(5) -> true
    调用 isBadVersion(4) -> true
    
    所以,4 是第一个错误的版本。 
    

    题目分析

    1. 根据题目描述求出错的第一个版本
    2. 使用二分查找的思想

    代码

    // The API isBadVersion is defined for you.
    // bool isBadVersion(int version);
    
    class Solution {
    public:
        int firstBadVersion(int n) {
            int left = 1;
            int right = n;
            int mid = left + (right - left) / 2;
            while (left < right) {
                mid = left + (right - left) / 2;
                bool res = isBadVersion(mid);
                if (res) right = mid;
                else left = mid + 1;
            }
            return left;
        }
    };
    
  • 相关阅读:
    215. Kth Largest Element in an Array
    214. Shortest Palindrome
    213. House Robber II
    212. Word Search II
    210 Course ScheduleII
    209. Minimum Size Subarray Sum
    208. Implement Trie (Prefix Tree)
    207. Course Schedule
    206. Reverse Linked List
    sql 开发经验
  • 原文地址:https://www.cnblogs.com/HanYG/p/14884475.html
Copyright © 2011-2022 走看看