Java解决矩阵中局部最大值

Java解决矩阵中局部最大值

01 题目

给你一个大小为 n x n 的整数矩阵 grid

生成一个大小为 (n - 2) x (n - 2) 的整数矩阵 maxLocal ,并满足:

  • maxLocal[i][j] 等于 grid 中以 i + 1 行和 j + 1 列为中心的 3 x 3 矩阵中的 最大值

换句话说,我们希望找出 grid 中每个 3 x 3 矩阵中的最大值。

返回生成的矩阵。

示例 1:

输入:grid = [[9,9,8,1],[5,6,2,6],[8,2,6,4],[6,2,2,2]]
输出:[[9,9],[8,6]]
解释:原矩阵和生成的矩阵如上图所示。
注意,生成的矩阵中,每个值都对应 grid 中一个相接的 3 x 3 矩阵的最大值。

示例 2:

输入:grid = [[1,1,1,1,1],[1,1,1,1,1],[1,1,2,1,1],[1,1,1,1,1],[1,1,1,1,1]]
输出:[[2,2,2],[2,2,2],[2,2,2]]
解释:注意,2 包含在 grid 中每个 3 x 3 的矩阵中。

提示:

  • n == grid.length == grid[i].length
  • 3 <= n <= 100
  • 1 <= grid[i][j] <= 100

02 知识点

  • 二维数组
  • 矩阵

03 我的题解

java 复制代码
public class shuzu07 {
public static void main(String[] args) {
	//测试数据
	int[][] rs=new int[][] {
	//			{1,1,1,1,1},
//			{1,1,1,1,1},
//			{1,1,2,1,1},
//			{1,1,1,1,1},
//			{1,1,1,1,1}
			{9,9,8,1},
			{5,6,2,6},
			{8,2,6,4},
			{6,2,2,2}
			};
	//用于展示数据,不重要
	int[][] rs1=largestLocal(rs);
	for (int i = 0; i < rs1.length; i++) {
		for (int j = 0; j < rs1[0].length; j++) {
			System.out.println(rs1[i][j]);
		}
	}
	}
public static int[][] largestLocal(int[][] grid) {
	//根据题设获得返回的数组
	int n=grid.length;
	int[][] rs=new int[n-2][n-2];
	
	//双重循环,从每行每列第二个开始,倒二个结束
	for (int i = 1; i < grid.length-1; i++) {
		for (int j = 1; j < grid[0].length-1; j++) {
			//拿到一个3x3的数组,遍历寻找最大值
			int[][] nums=new int[][] {
				{grid[i-1][j-1],	grid[i-1][j],	grid[i-1][j+1]},
				{grid[i][j-1],		grid[i][j],		grid[i][j+1]},
				{grid[i+1][j-1],	grid[i+1][j],	grid[i+1][j+1]}
			};
			//把封装的函数获取的最大值赋个结果数组
			rs[i-1][j-1]=msMax(nums);
		}
	}
	
	return rs;
}
public static int msMax(int[][] nums) {
	int max=0;
	//遍历整个数组,遇到比max更大的就改变max值
	for (int i = 0; i < nums.length; i++) {
		for (int j = 0; j < nums[0].length; j++) {
			max=Math.max(max, nums[i][j]);
		}
		
	}
	return max;
}
}

相关推荐
TJKFYY几秒前
Java.数据结构.HashSet
java·开发语言·数据结构
kylinxjd2 分钟前
spring boot发送邮件
java·spring boot·后端·发送email邮件
OLDERHARD10 分钟前
Java - MyBatis(上)
java·oracle·mybatis
杨荧11 分钟前
【JAVA开源】基于Vue和SpringBoot的旅游管理系统
java·vue.js·spring boot·spring cloud·开源·旅游
大二转专业2 小时前
408算法题leetcode--第24天
考研·算法·leetcode
zaim12 小时前
计算机的错误计算(一百一十四)
java·c++·python·rust·go·c·多项式
凭栏落花侧2 小时前
决策树:简单易懂的预测模型
人工智能·算法·决策树·机器学习·信息可视化·数据挖掘·数据分析
hong_zc3 小时前
算法【Java】—— 二叉树的深搜
java·算法
进击的女IT4 小时前
SpringBoot上传图片实现本地存储以及实现直接上传阿里云OSS
java·spring boot·后端
吱吱鼠叔4 小时前
MATLAB计算与建模常见函数:5.曲线拟合
算法·机器学习·matlab