美文网首页
二维数组中查找某个数是否存在

二维数组中查找某个数是否存在

作者: uzck | 来源:发表于2017-03-26 10:08 被阅读0次

题目很明了,给一个二位数组,二维数组从左到右逐渐增大,从上到下逐渐增大,再给一个要查找的数,判断数组里是否存在该数字。

最无脑的版本

下面的解法应该是排除直接双重循环之后最无脑的解法了,每次都先对一维数组进行判断,如果array[i][0] <= target && array[i][array[0].length - 1] >= target,就对这个数组进行一次遍历,查找目标数,如果存在返回true,否则进行下一次循环。

public static boolean Find(int target, int[][] array) {
        if (array == null) {
            return false;
        }
        if (array.length <= 0) {
            return false;
        }

        for (int i = 0; i < array.length; i++) {
            if (array[i][0] <= target && array[i][array[0].length - 1] >= target) {
                for (int j = 0; j < array[0].length; j++) {
                    if (target == array[i][j]) {
                        return true;
                    }
                }
            }
        }
        return false;
    }

稍微动点脑子

上面的程序明显可以优化,最坏情况还是O(n^2),即每个一维数组都符合if中的条件,从而进行一次查找。那么查找程序是否还可以优化呢,利用题目的条件:从左到右是递增的,那么利用二分查找可以将程序的最坏复杂度优化至O(nlogn)

if (array == null) {
            return false;
        }
        if (array.length == 0) {
            return false;
        }
        if (array[0].length <= 0) {
            return false;
        }

        for (int i = 0; array.length > 0 && i < array.length; i++) {
            if (array[i][0] <= target && array[i][array[0].length - 1] >= target) {
                int x = 0, y = array[0].length - 1, mid = (x + y) / 2;
                while (x <= y) {
                    if (array[i][mid] > target) {
                        y = mid - 1;
                        mid = (x + y) / 2;
                    } else if (array[i][mid] < target) {
                        x = mid + 1;
                        mid = (x + y) / 2;
                    } else {
                        return true;
                    }
                }
            }
        }
        return false;

更简单的方法

在讨论区找到了更简单的方法,通过从左下角开始搜索

public static boolean Find(int target, int[][] array) {
        int len = array.length - 1;
        int i = 0;
        while ((len >= 0) && (i < array[0].length)) {
            if (array[len][i] > target) {
                len--;
            } else if (array[len][i] < target) {
                i++;
            } else {
                return true;
            }
        }
        return false;
}

这种算法下如果是一个M x N的二维数组,复杂度为O(M + N)。同样的思路从右下角开始搜索也是可以的。

相关文章

  • 算法题

    行列都是有序的二维数组,查找k是否存在【查找法】 二维数组中的查找(行列分别有序数组的二分查找)【递归法】 快速排...

  • 二维数组中查找某个数是否存在

    题目很明了,给一个二位数组,二维数组从左到右逐渐增大,从上到下逐渐增大,再给一个要查找的数,判断数组里是否存在该数...

  • 数组查找操作

    数组常见的查找操作如下: 需求:给一个数组,查找某个元素在数组中的位置,如果该元素不存在,则返回-1。//正常查找...

  • flutter 数组 工具

    flutter中对比两个数组相同 16进制打印数组 从a数组中查询b数组是否存在及存在的位置

  • 数组的去重、获取下标、删除、添加等各种操作

    1.数组去除空值 2.通过某元素获取在数组中对应的下标(也是判断是否存在于这个数组中) 3.改变数组对象中元素的值...

  • day08字符串

    数组元素类型 数组名称[元素个数] 二维数组: 数组中的每一个元素又是一个数组, 那么这个数组就称之为二维数组元素...

  • 剑指Offer二维数组查找

    剑指Offer二维数组查找 二维数组查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到...

  • 还在傻傻分不清ES5、Es6数组方法?各大姿势来袭

    Es6 + includes 用途: 检测数组中是否存在该元素,返回Boolean值 find 用途: 查找数组的...

  • 2017/05/11 二维数组查找

    题目搬运: 例如下面的二维数组,每行每列都是递增,如果在数组中查找数字7,则返回true;如果查找5,因为5不存在...

  • 二分法查找

    二分法查找 : 目的 : 查找一个数组中是否含义某个元素 : 有返回数组中的位置 ,没有返回 -1 算法: 二分法...

网友评论

      本文标题:二维数组中查找某个数是否存在

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