国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

LeetCode-74. 搜索二維矩陣【數(shù)組 二分查找 矩陣】

這篇具有很好參考價(jià)值的文章主要介紹了LeetCode-74. 搜索二維矩陣【數(shù)組 二分查找 矩陣】。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

題目描述:

給你一個(gè)滿足下述兩條屬性的 m x n 整數(shù)矩陣:

  • 每行中的整數(shù)從左到右按非嚴(yán)格遞增順序排列。
  • 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。

給你一個(gè)整數(shù) target ,如果 target 在矩陣中,返回 true ;否則,返回 false 。

示例 1:
LeetCode-74. 搜索二維矩陣【數(shù)組 二分查找 矩陣】,算法題,leetcode,矩陣,算法,二分查找,python
輸入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
輸出:true
示例 2:
LeetCode-74. 搜索二維矩陣【數(shù)組 二分查找 矩陣】,算法題,leetcode,矩陣,算法,二分查找,python
輸入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
輸出:false

提示:

m == matrix.length
n == matrix[i].length
1 <= m, n <= 100
-104 <= matrix[i][j], target <= 104

解題思路一:先二分查找行,再二分查找列。

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

# 同意
class Solution(object):
    def searchMatrix(self, matrix, target):
        M, N = len(matrix), len(matrix[0])
        col0 = [row[0] for row in matrix]
        target_row = bisect.bisect_right(col0, target) - 1
        if target_row < 0:
            return False
        target_col = bisect.bisect_left(matrix[target_row], target)
        if target_col >= N:
            return False
        if matrix[target_row][target_col] == target:
            return True
        return False

時(shí)間復(fù)雜度:O(logn + logm)
空間復(fù)雜度:O(1)

解題思路二:暴力遍歷,也能過。

class Solution(object):
    def searchMatrix(self, matrix, target):
        M, N = len(matrix), len(matrix[0])
        for i in range(M):
            for j in range(N):
                if matrix[i][j] == target:
                    return True
        return False

時(shí)間復(fù)雜度:O(nm)
空間復(fù)雜度:O(1)

解題思路三:用python的in。

class Solution(object):
    def searchMatrix(self, matrix, target):
        M, N = len(matrix), len(matrix[0])
        for i in range(M):
            if target > matrix[i][N - 1]:
                continue
            if target in matrix[i]:
                return True
        return False

時(shí)間復(fù)雜度:O(logn + m)
空間復(fù)雜度:O(1)文章來源地址http://www.zghlxwxcb.cn/news/detail-850976.html

到了這里,關(guān)于LeetCode-74. 搜索二維矩陣【數(shù)組 二分查找 矩陣】的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • LeetCode【74】搜索二維矩陣

    LeetCode【74】搜索二維矩陣

    題目: 代碼:

    2024年02月07日
    瀏覽(22)
  • leetcode 74.搜索二維矩陣

    本題其實(shí)就是一個(gè)變形的二分查找而已。這里不采用兩次二分或者一次二分的方法了,leetcode上是很詳細(xì)的,這里就講講普通的思路是怎樣的。 思路:首先就是把二維數(shù)組化為一維數(shù)組,這個(gè)時(shí)候一維數(shù)組需要開的大一些,不然的話會(huì)過不了一些大數(shù)據(jù)樣例。依次把二維數(shù)組

    2024年04月11日
    瀏覽(19)
  • Leetcode74. 搜索二維矩陣

    Leetcode74. 搜索二維矩陣

    給你一個(gè)滿足下述兩條屬性的? m x n ?整數(shù)矩陣: 每行中的整數(shù)從左到右按非遞減順序排列。 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 給你一個(gè)整數(shù)? target ?,如果? target ?在矩陣中,返回? true ?;否則,返回? false ?。 ? ?

    2024年02月11日
    瀏覽(19)
  • leetcode 74. 搜索二維矩陣(java)

    leetcode 74. 搜索二維矩陣(java)

    來源:力扣(LeetCode) 鏈接:https://leetcode.cn/problems/search-a-2d-matrix 給你一個(gè)滿足下述兩條屬性的 m x n 整數(shù)矩陣: 每行中的整數(shù)從左到右按非遞減順序排列。 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 給你一個(gè)整數(shù) target ,如果 target 在矩陣中,返回 true ;否則,返回

    2024年02月16日
    瀏覽(14)
  • 【LeetCode熱題100】--74.搜索二維矩陣

    【LeetCode熱題100】--74.搜索二維矩陣

    按行搜索,使用二分查找

    2024年02月02日
    瀏覽(20)
  • leetcode做題筆記74搜索二維矩陣

    給你一個(gè)滿足下述兩條屬性的? m x n ?整數(shù)矩陣: 每行中的整數(shù)從左到右按非遞減順序排列。 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 給你一個(gè)整數(shù)? target ?,如果? target ?在矩陣中,返回? true ?;否則,返回? false ?。 本題可直接遍歷整個(gè)矩陣進(jìn)行查找 本題考察矩

    2024年02月13日
    瀏覽(17)
  • LeetCode 熱題 100 JavaScript -- 74. 搜索二維矩陣

    LeetCode 熱題 100 JavaScript -- 74. 搜索二維矩陣

    給你一個(gè)滿足下述兩條屬性的 m x n 整數(shù)矩陣: 每行中的整數(shù)從左到右按非遞減順序排列。 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 給你一個(gè)整數(shù) target ,如果 target 在矩陣中,返回 true ;否則,返回 false 。

    2024年02月13日
    瀏覽(18)
  • E : B DS二分查找_搜索二維矩陣

    使用二分查找法來判斷m*n矩陣matrix中是否存在目標(biāo)值target。 該矩陣有以下特性: 每行中的整數(shù)從左到右升序排列; 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 第一行輸入m和n,分別表示矩陣的行數(shù)和列數(shù),接著輸入m*n個(gè)整數(shù)。 接著,輸入查找次數(shù)t,接著依次輸入t個(gè)整

    2024年02月04日
    瀏覽(17)
  • leetcode(矩陣)74. 搜索二維矩陣(C++詳細(xì)解釋)DAY7

    leetcode(矩陣)74. 搜索二維矩陣(C++詳細(xì)解釋)DAY7

    給你一個(gè)滿足下述兩條屬性的 m x n 整數(shù)矩陣: 每行中的整數(shù)從左到右按非嚴(yán)格遞增順序排列。 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)。 給你一個(gè)整數(shù) target ,如果 target 在矩陣中,返回 true ;否則,返回 false 。 m == matrix.length n == matrix[i].length 1 = m, n = 100 -10^ 4 = matrix

    2024年02月19日
    瀏覽(23)
  • LeetCode74.Search-A-2d-Matrix<搜索二維矩陣>

    LeetCode74.Search-A-2d-Matrix<搜索二維矩陣>

    題目: ? 思路: 矩陣,搜索數(shù)是否在矩陣內(nèi)。那就查找他是否在每一行中。如果符合這一行的范圍,那就一直找這一列是否存在,如果存在返回true;否則false; ?

    2024年02月16日
    瀏覽(23)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包