二维数组中的查找

原文链接:http://blog.csdn.net/qq_22329521/article/details/52948041

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

enter image description here

解决思路:
从二维数组的右上角的元素开始判断,因为此元素是它所在行的最大数,是它所在的列的最小数。如果它等于要查找的数字,则查找过程结束。如果它大于要查找的数字,则可以排除它所在的列。如果它小于要查找的数字,则可排除它所在的行。这样如果要查找的数字不在数组的右上角,则每次判断都可以排除一行或一列以缩小查找范围,直到找到要查找的数字,或者查找范围为空


enter image description here
private static void suzhu1() {
        int[][] arr = {{1, 2, 8, 9}, {2, 4, 9, 12}, {4, 7, 10, 13}, {6, 8, 11, 15}};
        int target = 7;
        int rows = arr.length;
        int columns = arr[0].length;
        int row = 0;
        int column = columns - 1;

        while (row <= rows && column >= 0) {
            if (target == arr[row][column]) {
                System.out.println(target + "在第" + row + "行,第" + column + "列");
                break;
            }
            if (target > arr[row][column]) {
                row++;
            }
            if (target < arr[row][column]) {
                column--;
            }
        }
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输...
    913c9536e19a阅读 3,064评论 0 0
  • 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输...
    minningl阅读 3,335评论 0 0
  • 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样...
    四毛哥掉落的鳞片阅读 4,505评论 0 0
  • 题目描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数...
    柚子槑阅读 1,319评论 0 0
  • 题目要求 在一个二维数组中,每一行都会按照从左至右递增的规律排列,每一列都会按照从上到下递增的规律排列。请完成一个...
    小庄bb阅读 1,153评论 0 0

友情链接更多精彩内容