題目描述:你是產品經理,目前正在帶領乙個團隊開發新的產品。不幸的是,你的產品的最新版本沒有通過質量檢測。由於每個版本都是基於之前的版本開發的,所以錯誤的版本之後的所有版本都是錯的。假設你有 n 個版本 [1, 2, …, n],你想找出導致之後所有版本出錯的第乙個錯誤的版本。你可以通過呼叫 bool isbadversion(version) 介面來判斷版本號 version 是否在單元測試**錯。實現乙個函式來查詢第乙個錯誤的版本。你應該儘量減少對呼叫 api 的次數。
示例:
給定 n =
5,並且 version =
4 是第乙個錯誤的版本。
呼叫 isbadversion(3
)-> false
呼叫 isbadversion(5
)-> true
呼叫 isbadversion(4
)-> true
所以,4 是第乙個錯誤的版本。
解題思路:首先是二分迴圈,然後如果是當前true就代表以後的都是true,所有要進入到左邊繼續查詢還有沒有true的結點,反之如果是false,就代表之前的都是false,進入到右邊繼續查詢。bool isbadversion
(int version)
;int
firstbadversion
(int n)
while
(left<=right)
elseif(
!isbadversion
(mid))}
if(is_false)
return-1
;}
278 第乙個錯誤的版本
你是產品經理,目前正在帶領乙個團隊開發新的產品。不幸的是,你的產品的最新版本沒有通過質量檢測。由於每個版本都是基於之前的版本開發的,所以錯誤的版本之後的所有版本都是錯的。假設你有 n 個版本 1,2,n 你想找出導致之後所有版本出錯的第乙個錯誤的版本。你可以通過呼叫 bool isbadversio...
278 第乙個錯誤的版本
278.第乙個錯誤的版本 你是產品經理,目前正在帶領乙個團隊開發新的產品。不幸的是,你的產品的最新版本沒有通過質量檢測。由於每個版本都是基於之前的版本開發的,所以錯誤的版本之後的所有版本都是錯的。假設你有n個版本 1,2,n 你想找出導致之後所有版本出錯的第乙個錯誤的版本。你可以通過呼叫bool i...
278 第乙個錯誤的版本(c )
你是產品經理,目前正在帶領乙個團隊開發新的產品。不幸的是,你的產品的最新版本沒有通過質量檢測。由於每個版本都是基於之前的版本開發的,所以錯誤的版本之後的所有版本都是錯的。假設你有 n 個版本 1,2,n 你想找出導致之後所有版本出錯的第乙個錯誤的版本。你可以通過呼叫 bool isbadversio...