【剑指offer】 二维数组中的查找 、 0~n-1中缺失的数字

278 阅读1分钟

这是我参与8月更文挑战的第16天,活动详情查看:8月更文挑战

题目

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

来源:力扣(LeetCode)
链接:leetcode-cn.com/problems/er…
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

我的答案

/**
 * @param {number[][]} matrix
 * @param {number} target
 * @return {boolean}
 */
var findNumberIn2DArray = function (matrix, target) {
    if(matrix.length===0){
        return false;
    }
    var i = 0;
    var j = matrix[0].length - 1;
    while (matrix[i][j] !== target) {
        if (matrix[i][j] > target) {
            j--;
        } else if (matrix[i][j] < target) {
            i++;
        }
        if(i>=matrix.length || j<0){
            return false;
        }
    }
    return true;
};

如果按照顺着题目的思维,这道题会变得非常麻烦。想要快速找到,就需要尽可能找到比较简单的寻找路径。与元素比较大小的结果只会导向一个方向。我们注意到,从二维数组的右上角(或左下角)开始,比较大小后只有向左向下(或向上向右)。如果超出数据的界限了,就说明没有。

题目

一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。

来源:力扣(LeetCode)
链接:leetcode-cn.com/problems/qu…
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

我的答案

/**
 * @param {number[]} nums
 * @return {number}
 */
var missingNumber = function (nums) {
    return nums.length * (nums.length + 1) / 2 - nums.reduce((res, item) => res + item, 0);
};

最简单最不费脑子的就是做数学题,用1~n-1的和减去数组的和。