每日一题(小白)暴力娱乐篇30

顺时针旋转,从上图中不难看出行列进行了变换。因为这是一道暴力可以解决的问题,我们直接尝试使用行列转换看能不能得到想要的结果。

复制代码
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
	    int n=scan.nextInt();
	    int m=scan.nextInt();
	    int count=0;
	    for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				arr[i][j]=scan.nextInt();
			}
		}
	    for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				System.out.print(arr[j][i]+" ");
			}
			System.out.println();
		}
		scan.close();
	}

如上图所示我们将行列直接转换,但是我们会得到如下的示例结果。由于在进行行列转换的时候,将预先的3行变成4列,4列变成三行超出了原来的数组长度导致了出现0并且转换错误的情况。接下来我们观察一下顺时针转换的下标的位置变化规律可以发现1 3 5 7由原来的第一行(0,0)~(0,3)转换为第三列(0,2)~(3,2),我们不难发现坐标在原来的基础上实现的是行递增,列不变。

复制代码
3 4
1 3 5 7
9 8 7 6
3 5 9 7
1 9 3 0 
3 8 5 0 
5 7 9 0 

代码实现👇

复制代码
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
	    int n=scan.nextInt();
	    int m=scan.nextInt();
	    int count=0;
	    for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				arr[i][j]=scan.nextInt();
			}
		}
	    for (int i = 0; i < m; i++) {//行变为列的大小
			for (int j = n-1; j >=  0; j--) {//列每次按原来的行递减输出
				System.out.print(arr[j][i]+" ");
			}
			System.out.println();
		}
		scan.close();
	}

大家多动手,比较简单

相关推荐
圣保罗的大教堂1 分钟前
《算法笔记》13.2小节——专题扩展->树状数组(BIT) 问题 D: 数列-训练套题T10T3
算法
Pluchon7 分钟前
硅基计划2.0 学习总结 伍 类的继承 初稿
java·开发语言·学习·算法·markdown
ergdfhgerty14 分钟前
飞牛NAS+Docker技术搭建个人博客站:公网远程部署实战指南
java·docker·容器
Timmer丿23 分钟前
kafka学习笔记(三、消费者Consumer使用教程——从指定位置消费)
java·笔记·学习·kafka
lifallen30 分钟前
Apache Paimon:存储结构、写入及其源码分析
java·大数据·数据仓库·sql·flink·database
召田最帅boy41 分钟前
基于URL弹窗的图片链接生成功能技术实现
android·java·javascript
apocelipes1 小时前
golang遍历处理map时的常见性能陷阱
数据结构·性能优化·golang·哈希表·hashtable
Code哈哈笑1 小时前
【基于SpringBoot的图书购买系统】操作Jedis对图书图书的增-删-改:从设计到实战的全栈开发指南
java·spring boot·后端·spring·交互·jedis
笨鸟起飞1 小时前
CODEFORCES----1999A - A+B Again?
数据结构·c++·算法
珹洺1 小时前
计算机操作系统(十四)互斥锁,信号量机制与整型信号量
java·redis·缓存