- Published on
Leetcode 278 - First Bad Version solution
- Authors
- Name
- Imran Pollob
- Website
- @pollmix
Solution
We will use binary search technique here because the time complexity should be log n
# The isBadVersion API is already defined for you.
# @param version, an integer
# @return an integer
# def isBadVersion(version):
class Solution:
def firstBadVersion(self, n):
"""
:type n: int
:rtype: int
"""
if n == 1:
return 1
left = 1
right = n
while left <= right:
mid = (left + right) // 2
if isBadVersion(mid):
right = mid - 1
else:
left = mid + 1
return left