Lintcode: First Bad Version

The code base version is an integer and start from 1 to n. One day, someone commit a bad version in the code case, so it caused itself and the following versions are all failed in the unit tests.
You can determine whether a version is bad by the following interface: 

Java:
    public VersionControl {
        boolean isBadVersion(int version);
    }
C++:
    class VersionControl {
    public:
        bool isBadVersion(int version);
    };
Python:
    class VersionControl:
        def isBadVersion(version)

Find the first bad version.
Note
You should call isBadVersion as few as possible. 

Please read the annotation in code area to get the correct way to call isBadVersion in different language. For example, Java is VersionControl.isBadVersion.

Example
Given n=5

Call isBadVersion(3), get false

Call isBadVersion(5), get true

Call isBadVersion(4), get true

return 4 is the first bad version

Challenge
Do not call isBadVersion exceed O(logn) times.

 

就是一个找第一次出现的边沿的题目,方法是Binary Search, 只不过左右指针肯定会重合的,重合之后左指针所在的位置就是左边沿

isBadVersion是个Class Method, 所以调用的方式是类的名字+方法名字

* public class VersionControl {
* public static boolean isBadVersion(int k);
* }

 1 /**
 2  * public class VersionControl {
 3  *     public static boolean isBadVersion(int k);
 4  * }
 5  * you can use VersionControl.isBadVersion(k) to judge wether 
 6  * the kth code version is bad or not.
 7 */
 8 class Solution {
 9     /**
10      * @param n: An integers.
11      * @return: An integer which is the first bad version.
12      */
13     public int findFirstBadVersion(int n) {
14         int l = 1;
15         int r = n;
16         while (l <= r) {
17             int m = (l + r) / 2;
18             if (VersionControl.isBadVersion(m)) {
19                 r = m - 1;
20             }
21             else {
22                 l = m + 1;
23             }
24         }
25         return l;
26     }
27 }

 

转载于:https://www.cnblogs.com/EdwardLiu/p/4278295.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值