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;
}
}

相关推荐
不吃香菜学java4 小时前
Redis的java客户端
java·开发语言·spring boot·redis·缓存
captain3764 小时前
事务___
java·数据库·mysql
北漂Zachary5 小时前
四大编程语言终极对比
android·java·php·laravel
小江的记录本5 小时前
【网络安全】《网络安全常见攻击与防御》(附:《六大攻击核心特性横向对比表》)
java·网络·人工智能·后端·python·安全·web安全
白羊by5 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
嗑嗑嗑瓜子的猫6 小时前
Java!它值得!
java·开发语言
墨尘笔尖7 小时前
最大最小值降采样算法的优化
c++·算法
2401_895521347 小时前
【Spring Security系列】Spring Security 过滤器详解与基于JDBC的认证实现
java·后端·spring
皮卡蛋炒饭.7 小时前
线程的概念和控制
java·开发语言·jvm
一只大袋鼠7 小时前
MyBatis 入门详细实战教程(一):从环境搭建到查询运行
java·开发语言·数据库·mysql·mybatis