搜索二維矩陣 II(LeetCode 240)

題目

編寫一個高效的算法來搜索 m x n 矩陣 matrix 中的一個目標(biāo)值 target。該矩陣具有以下特性:

每行的元素從左到右升序排列。
每列的元素從上到下升序排列。

示例:

現(xiàn)有矩陣 matrix 如下:

[
[1, 4, 7, 11, 15],
[2, 5, 8, 12, 19],
[3, 6, 9, 16, 22],
[10, 13, 14, 17, 24],
[18, 21, 23, 26, 30]
]

給定 target = 5,返回 true。

給定 target = 20,返回 false。

解析

1.以右上角或者左下角為起點
2.例如以右上角,若target大于右上角matrix [i,j],則行數(shù)+1,若target小于matrix [i,j],則,列數(shù)減一
3.注意,二維數(shù)組的長度獲取是matrix .GetLength(0) 行數(shù),matrix .GetLength(1)列數(shù)

代碼

public class Solution {
  public bool SearchMatrix(int[,] matrix, int target)
    {
        if (matrix.GetLength(0) == 0 || matrix.GetLength(1) == 0)
            return false;
        int i = matrix.GetLength(0)-1, j = 0;
        while (i>=0&&j<matrix.GetLength(1))
        {
            if (target == matrix[i, j]) return true;
            else if(target>matrix[i,j])
            {
                j++;
            }
            else
            {
                i--;
            }
        }

        return false;
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容