每日一题(小白)暴力娱乐篇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();
	}

大家多动手,比较简单

相关推荐
JMchen1231 分钟前
Android计算摄影实战:多帧合成、HDR+与夜景算法深度剖析
android·经验分享·数码相机·算法·移动开发·android-studio
tsyjjOvO3 分钟前
JDBC(Java Database Connectivity)
java·数据库
阿猿收手吧!7 分钟前
【C++】C++模板特化:精准定制泛型逻辑
开发语言·c++·算法
qq_12498707537 分钟前
基于springboot的尿毒症健康管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·spring·毕业设计·计算机毕业设计
智驱力人工智能20 分钟前
货车走快车道检测 高速公路安全治理的工程实践与价值闭环 高速公路货车占用小客车道抓拍系统 城市快速路货车违规占道AI识别
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
喵手30 分钟前
Python爬虫实战:电商实体消歧完整实战 - 从混乱店铺名到标准化知识库的工程化实现,一文带你搞定!
爬虫·python·算法·爬虫实战·零基础python爬虫教学·同名实体消除·从混乱店铺名到标准化知识库
weixin_4521595534 分钟前
C++与Java性能对比
开发语言·c++·算法
80530单词突击赢35 分钟前
C++哈希表实现:开散列与闭散列详解
算法·哈希算法·散列表
Timmylyx051838 分钟前
类欧几里得学习笔记
笔记·学习·算法
wangluoqi40 分钟前
26.2.2练习总结
算法