美文网首页
面试题3:二维数组中的查找(剑指Offer)

面试题3:二维数组中的查找(剑指Offer)

作者: 辉辉_teresa | 来源:发表于2021-01-30 19:54 被阅读0次

    题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

    public bool FindNumberIn2DArray(int[][] matrix, int target)
    {
        if (matrix.Length == 0 || matrix[0].Length == 0)
            return false;
        var rows = matrix.Length;
        var cols = matrix[0].Length;
        var row = 0;
        var col = cols-1;
        while (row<rows && col>=0)
        {
            if (matrix[row][col] == target)
                return true;
            if (target > matrix[row][col])
                row += 1;
            else
            {
                col -= 1;
            }
        }
        return false;
    }
    

    首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列;如果该数字小于要查找的数字,剔除这个数字所在的行。

    相关文章

      网友评论

          本文标题:面试题3:二维数组中的查找(剑指Offer)

          本文链接:https://www.haomeiwen.com/subject/pipktltx.html