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

题目描述

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

在这里插入图片描述

思路

详见链接

代码

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
发布了173 篇原创文章 · 获赞 505 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/weixin_37763870/article/details/105059344