当前位置:主页 > java教程 > java算法顺时针旋转矩阵

java算法题解牛客BM99顺时针旋转矩阵示例

发布:2023-03-04 08:00:01 59


本站精选了一篇相关的编程文章,网友宓意智根据主题投稿了本篇教程内容,涉及到java算法顺时针旋转矩阵、java、算法、java算法顺时针旋转矩阵相关内容,已被950网友关注,如果对知识点想更进一步了解可以在下方电子资料中获取。

java算法顺时针旋转矩阵

题目描述

BM99 顺时针旋转矩阵

描述 有一个NxN整数矩阵,请编写一个算法,将矩阵顺时针旋转90度。 给定一个NxN的矩阵,和矩阵的阶数N,请返回旋转后的NxN矩阵。 数据范围:0<n<300,矩阵中的值满足0≤val≤1000

要求:空间复杂度 O(N^2),时间复杂度 O(N^2) 进阶:空间复杂度 O(1),时间复杂度 O(N^2)

示例1
输入:
[[1,2,3],[4,5,6],[7,8,9]],3
返回值:
[[7,4,1],[8,5,2],[9,6,3]]

解题思路

1.解法1:利用辅助数组,通过推导,我们知道每一位移动数字位置为:res[j][n-i-1] = mat[i][j];

2.解法2:我们观察,其实顺时针旋转90度,相等于,先按照做左对角线翻转数组,然后再按照列的中轴线翻转数组 实例分析:[[1,2,3],[4,5,6],[7,8,9]],3

实践代码

解法1

空间复杂度 O(N^2),时间复杂度 O(N^2)

import java.util.*;
public class Solution {
	public int[][] rotateMatrix(int[][] mat, int n) {
		int[][] res = new int[n][n]; //辅助数组
		for (int i = 0; i < res.length; i++) {
			for (int j = 0; j < res.length; j++) {
				res[j][n-i-1] = mat[i][j];
			}
		}
		return res;
	}
}

解法2

空间复杂度 O(1),时间复杂度 O(N^2)

import java.util.*;
public class Solution {
	public int[][] rotateMatrix(int[][] mat, int n) {
		//按照做左对角线翻转数组
		for (int i = 0; i < mat.length; i++) {
			for (int j = i; j < mat.length; j++) {
				int temp = mat[i][j];
				mat[i][j] = mat[j][i];
				mat[j][i] = temp;
			}
		}
		//再按照列的中轴线翻转数组
		for (int i = 0; i < mat.length / 2; i++) {
			for (int j = 0; j < mat.length; j++) {
				int temp = mat[j][i];
				mat[j][i] = mat[j][n - i - 1];
				mat[j][n - i - 1] = temp;
			}
		}
		return mat;
	}
}

以上就是java算法题解牛客BM99顺时针旋转矩阵示例的详细内容,更多关于java算法顺时针旋转矩阵的资料请关注码农之家其它相关文章!


参考资料

相关文章

  • Java方法递归的形式和常见递归算法(方法递归结合File类查找文件)

    发布:2023-03-21

    方法递归方法直接调用自己或者间接调用自己的形式称为方法递归( recursion),递归做为一种算法在程序设计语言中广泛应用,这篇文章主要介绍了Java方法递归的形式和常见递归算法-方法递归结合File类查找文件,需要的朋友可以参考下


  • 浅谈java什么时候需要用序列化 

    发布:2023-04-26

    本文主要介绍了浅谈java什么时候需要用序列化,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • Java ArrayList实现删除指定位置的元素

    发布:2023-03-03

    目标:list中有0到39共40个元素,删除其中索引是10、20、30的元素。本文为大家整理了三个不同的方法,感兴趣的小伙伴可以跟随小编一起学习一下


  • JavaScript 中的 JSON的知识点整理

    发布:2020-03-26

    我们先来看一个JS中常见的JS对象序列化成JSON字符串的问题,请问,以下JS对象通过JSON.stringify后的字符串是怎样的


  • 在Linux上搭建一个Java部署环境的详细步骤

    发布:2023-03-09

    这篇文章主要介绍了在Linux上搭建一个Java部署环境,安装jdk有很多种方式,但是我们这里推荐的是使用yum直接安装openjdk,本文给大家介绍的非常详细,需要的朋友可以参考下


  • Java API操作HDFS方法详细讲解

    发布:2023-03-29

    这篇文章主要介绍了Java API操作Hdfs详细示例,遍历当前目录下所有文件与文件夹,可以使用listStatus方法实现上述需求,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下


  • 关于java网络编程基础

    发布:2020-02-28

    这篇文章主要介绍了java网络编程基础知识介绍,涉及OSI分层模型和TCP/IP分层模型的对应关系、IP地址、端口号、tcp、udp等相关内容,还是比较不错的,这里分享给大家,供需要的朋友参考。


  • JavaScript中的ignoreCase属性使用方法

    发布:2020-01-05

    这篇文章主要介绍了JavaScript正则表达式中的ignoreCase属性使用详解,是JS学习进阶中的重要知识点,需要的朋友可以参考下


网友讨论