【力扣100】74.搜索二维矩阵 || 列表推导式

添加链接描述

python 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        # 把距阵变成列表,然后二分查找
        nums=[]
        m=len(matrix)
        n=len(matrix[0])
        for i in range(m):
            for j in range(n):
                nums.append(matrix[i][j])
        left,right=0,len(nums)-1
        if target<nums[0] or target>nums[right]:
            return False
        while left<=right:
            mid=left+(right-left)//2
            if target==nums[mid]:
                return True
            elif target<nums[mid]:
                right=mid-1
            else:
                left=mid+1
        return False
        

思路:

  1. 暴力求解
  2. 把矩阵降维,然后使用二分搜索


列表推导式

将二维数组变为一维数组中,使用列表推导式,会更加简便

python 复制代码
# 二维矩阵
matrix = [
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]
]

# 将二维矩阵转换为一维列表
flat_list = [element for row in matrix for element in row]

print(flat_list)


解法二:

python 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        m=len(matrix)
        n=len(matrix[0])
        i,j=0,m*n-1
        while i<=j:
            mid=i+(j-i)//2
            x=mid // n
            y=mid % n
            if target==matrix[x][y]:
                return True
            elif target<matrix[x][y]:
                j=mid-1
            else:
                i=mid+1
        return False

思路:

  1. 同样是二分查找,把mid对应的二维坐标找到就可以了
相关推荐
云泽80815 小时前
笔试算法 - 链表篇(一):移除、反转、合并、回文判断全解析
数据结构·c++·算法·链表
菜菜的顾清寒15 小时前
HOT力扣100(43)二叉树-翻转二叉树
数据结构·算法·leetcode
通信小呆呆15 小时前
Toeplitz结构及其快速算法详解
算法
YikNjy15 小时前
break和continue
java·开发语言·算法
春日见15 小时前
五分钟入门 强化学习---DQN(Deep Q Net)算法与实现
人工智能·python·深度学习·算法·microsoft·机器学习
budingxiaomoli16 小时前
动态规划--斐波那契数列模型
算法·动态规划
IT猿手16 小时前
多目标优化算法:多目标蛇优化算法(Multiple Objective Snake Optimizer,MOSO)(提供MATLAB代码)
开发语言·算法·matlab·动态路径规划·光伏模型参数估计
MegaDataFlowers16 小时前
101.对称二叉树
算法
Jasmine_llq17 小时前
《B3939 [GESP样题 四级] 绝对素数》
数据结构·算法·素数判断算法·数字拆分与反转算法·区间遍历枚举·双条件判断逻辑
郝学胜-神的一滴17 小时前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法