CCF题目: 图像旋转

时间:2021-07-12 21:31:28

问题描述

  旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转90度。
  计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可。

输入格式

  输入的第一行包含两个整数n, m,分别表示图像矩阵的行数和列数。
  接下来n行每行包含m个整数,表示输入的图像。

输出格式

  输出m行,每行包含n个整数,表示原始矩阵逆时针旋转90度后的矩阵。

样例输入

2 3
1 5 3
3 2 4

样例输出

3 4
5 2
1 3

评测用例规模与约定

  1 ≤ n, m ≤ 1,000,矩阵中的数都是不超过1000的非负整数。


===================================================================================

解答

代码如下:

package CSP4;

import java.util.Scanner;

public class InvPic {
	public static void main(String[] args) {
		new InvPic().run();
	}
	public void run(){
		Scanner sc=new Scanner(System.in);
		int M= sc.nextInt();
		int N=sc.nextInt();
		//int[][] arr=new int[M][N];
		int[][] arr=new int[N][M];
		for(int i=0;i<M;i++){
			for(int j=0;j<N;j++){
				arr[N-j-1][i]=sc.nextInt();  //需要找的规律,归纳法
			}
		}
		for(int i=0;i<N;i++){
			for(int j=0;j<M;j++){
				System.out.print(arr[i][j]+" ");
			}
			System.out.println();
		}
		
	}
}

和上面不同的是把
arr[N-j-1][i]=sc.nextInt();

展开了。

代码如下:

package CSP4;

import java.util.Scanner;

public class InvPic1 {
	public static void main(String[] args) {
		new InvPic().run();
	}
	public void run(){
		Scanner sc=new Scanner(System.in);
		int M= sc.nextInt();
		int N=sc.nextInt();
		int[][] arr=new int[N][M];
		for(int i=0;i<M;i++){
			for(int j=0;j<N;j++){
				arr[i][j]=sc.nextInt();
			}
		}
		for(int j=M-1;j>=0;j--){
			for(int i=0;i<N;i++){
				System.out.print(arr[j][i]+" ");
			}
			System.out.println();
		}
		
	}
}