結果

問題 No.565 回転拡大
ユーザー fal_rndfal_rnd
提出日時 2017-09-08 22:37:06
言語 Java
(openjdk 23)
結果
WA  
(最新)
AC  
(最初)
実行時間 -
コード長 1,020 bytes
コンパイル時間 4,962 ms
コンパイル使用メモリ 83,164 KB
実行使用メモリ 41,728 KB
最終ジャッジ日時 2024-11-07 06:23:02
合計ジャッジ時間 8,881 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 9 WA * 21
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.Arrays;
import java.util.Scanner;
import java.util.stream.IntStream;

public class Main{
	static IntStream REPS(int v){return IntStream.range(0,v);}
	static IntStream REPS(int l,int r){return IntStream.rangeClosed(l,r);}
	static IntStream INS(int n) {return REPS(n).map(i->getInt());}
	static Scanner s=new Scanner(System.in);
	static int getInt(){return Integer.parseInt(s.next());}

	public static void main(String[]$){
		int r=getInt(),k=getInt(),h=getInt(),w=getInt();
		char[][]in=new char[h*k][w*k];
		{
			char[][]buf=REPS(h).mapToObj(o->s.next().toCharArray()).toArray(char[][]::new);
			for(int i=0;i<h*k;++i) {
				for(int j=0;j<w*k;++j) {
					in[i][j]=buf[i/k][j/k];
				}
			}
		}
		for(int i=0;i<r;i+=90)
			in=turn(in);
		Arrays.stream(in).map(String::valueOf).forEach(System.out::println);
	}
	static char[][] turn(char[][]c){
		char[][] r=new char[c[0].length][c.length];
		for(int i=0;i<c[0].length;++i) {
			for(int j=0;j<c.length;++j) {
				r[i][j]=c[j][i];
			}
		}
		return r;
	}
}
0