【华为OD题库-056】矩阵元素的边界值-java

题目

给定一个N * M矩阵,请先找出M个该矩阵中每列元素的最大值,然后输出这M个值中的最小值

补充说明:

N和M的取值范围均为: [0,100]

示例1:
输入:

\[1,2\],\[3,4\]

输出:

3
说明:

第一列元素为:1和3,最大值为3

第二列元素为: 2和4,最大值为4

各列最大值3和4的最小值为3

思路

这道题应该比较简单,求每列最大值的最小值即可。

假定输入都是合法,不考虑输入不能构成二维数组的情况

题解

java 复制代码
package hwod;

import java.util.Arrays;
import java.util.Scanner;

public class MatrixBound {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s = sc.nextLine();
//        if("[[]]".equals(s)) return;
        String[] split = s.substring(2, s.length() - 2).split("],\\[");
        int m = split.length, n = split[0].split(",").length;
        int[][] nums = new int[m][n];
        for (int i = 0; i < m; i++) {
            nums[i] = Arrays.stream(split[i].split(",")).mapToInt(Integer::parseInt).toArray();
        }
        System.out.println(matrixBound(nums));

    }

    private static int matrixBound(int[][] nums) {
        int res = Integer.MAX_VALUE;
        int m = nums.length, n = nums[0].length;
        for (int j = 0; j < n; j++) {
            int colMax = Integer.MIN_VALUE;
            for (int i = 0; i < m; i++) {
                colMax = Math.max(colMax, nums[i][j]);
            }
            res = Math.min(res, colMax);
        }
        return res;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

相关推荐
CoderYanger1 分钟前
递归、搜索与回溯-综合练习:28.不同路径Ⅲ
java·算法·leetcode·深度优先·1024程序员节
鱼丸花生1 分钟前
Java 数组详解
java
用户84913717547162 分钟前
Tomcat 为什么要“造反”?深度解析 Java 类加载机制的“守”与“破”
java·jvm
jiayong238 分钟前
Elasticsearch Java 开发完全指南
java·大数据·elasticsearch
321茄子9 分钟前
MySQL 事务隔离性及锁
java·数据库·mysql
杀死那个蝈坦12 分钟前
UV 统计(独立访客统计)
java·jvm·spring·kafka·tomcat·maven
带刺的坐椅14 分钟前
Solon AI 开发学习7 - chat - 四种消息类型及提示语增强
java·ai·llm·solon
济宁雪人15 分钟前
Java安全基础——序列化/反序列化
java·开发语言
1***Q78415 分钟前
后端在微服务中的服务路由
java·数据库·微服务
q***017716 分钟前
Java进阶--IO流
java·开发语言