278第乙個錯誤的版本

2021-09-28 16:26:12 字數 814 閱讀 7738

題目描述:你是產品經理,目前正在帶領乙個團隊開發新的產品。不幸的是,你的產品的最新版本沒有通過質量檢測。由於每個版本都是基於之前的版本開發的,所以錯誤的版本之後的所有版本都是錯的。假設你有 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...