LeetCode74. 搜索二维矩阵(二分查找)

题目描述

编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值。该矩阵具有如下特性:
每行中的整数从左到右按升序排列。
每行的第一个整数大于前一行的最后一个整数。

LeetCode74. 搜索二维矩阵(二分查找)_第1张图片

思路

详见链接

代码

class Solution:
	def searchMatrix(self, matrix:List[List[int]], target:int)->bool:
	m = len(matrix)
	if m == 0:
		return False
	n = len(matrix[0])
	left, right = 0, m+n-1
	while left <= right:
		mid = (left + right) // 2
		element = matrix[mid // n][mid % n]
		if element == target:
			return True
		else:
			if element > target:
				right = mid - 1
			else:
				left = mid
	return False

你可能感兴趣的:(Leetcode,搜索二维矩阵,二分查找,leetcode,python)