Leetcode # 240 (Python): Search a 2D Matrix II

정욱·2021년 4월 28일
0

Leetcode

목록 보기
37/38
post-custom-banner

Search a 2D Matrix II

  • Difficulty: Medium
  • Type: Binary Search
  • link

Problem

Solution

  • Run binary search on row only if the last element is greater than the target
  • Time Complexity: O(n log n) (worst case)
import bisect
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        if not matrix:
            return False

        i = 0
        for row in matrix:
            if row[-1] < target:
                continue
            # Run Binary search
            elif row[-1] > target:
                i = bisect.bisect_left(row,target)
                if i < len(row) and row[i] == target:
                    return True
            else:
                return True
        return False
  • Simplest solution
  • Time Complexity: O(n log n)
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        return any(target in row for row in matrix)
post-custom-banner

0개의 댓글