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

添加链接描述

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. 把矩阵降维,然后使用二分搜索


列表推导式

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

# 二维矩阵
matrix = [
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]
]

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

print(flat_list)


解法二:

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对应的二维坐标找到就可以了

相关推荐

  1. 100】74.搜索矩阵 || 列表推导

    2024-01-09 11:12:02       59 阅读
  2. -搜索矩阵

    2024-01-09 11:12:02       40 阅读
  3. 100】240.搜索矩阵2

    2024-01-09 11:12:02       68 阅读
  4. 【算法详解】240.搜索矩阵II

    2024-01-09 11:12:02       41 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-09 11:12:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-09 11:12:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-01-09 11:12:02       82 阅读
  4. Python语言-面向对象

    2024-01-09 11:12:02       91 阅读

热门阅读

  1. Android如何判断scrollview滚到底部

    2024-01-09 11:12:02       54 阅读
  2. PG数据库更新表字段排序

    2024-01-09 11:12:02       55 阅读
  3. MySQL 8.0中新增的功能(七)

    2024-01-09 11:12:02       37 阅读
  4. git常用工具difftool的使用

    2024-01-09 11:12:02       47 阅读
  5. SQL-DML小结

    2024-01-09 11:12:02       59 阅读
  6. Bluez交叉编译

    2024-01-09 11:12:02       60 阅读
  7. C++ STL中vector的模拟实现

    2024-01-09 11:12:02       59 阅读
  8. 安卓adb

    2024-01-09 11:12:02       56 阅读
  9. 逐步递进地手写一个Promise

    2024-01-09 11:12:02       50 阅读