結果

問題 No.565 回転拡大
ユーザー tsuchinagatsuchinaga
提出日時 2019-03-27 13:00:14
言語 Go
(1.22.1)
結果
AC  
実行時間 9 ms / 2,000 ms
コード長 1,115 bytes
コンパイル時間 11,707 ms
コンパイル使用メモリ 224,176 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-04-19 09:51:41
合計ジャッジ時間 11,696 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 9 ms
6,816 KB
testcase_01 AC 5 ms
6,816 KB
testcase_02 AC 3 ms
6,940 KB
testcase_03 AC 1 ms
6,944 KB
testcase_04 AC 3 ms
6,944 KB
testcase_05 AC 2 ms
6,940 KB
testcase_06 AC 4 ms
6,944 KB
testcase_07 AC 3 ms
6,944 KB
testcase_08 AC 4 ms
6,944 KB
testcase_09 AC 2 ms
6,940 KB
testcase_10 AC 1 ms
6,940 KB
testcase_11 AC 2 ms
6,944 KB
testcase_12 AC 4 ms
6,944 KB
testcase_13 AC 2 ms
6,944 KB
testcase_14 AC 1 ms
6,940 KB
testcase_15 AC 3 ms
6,944 KB
testcase_16 AC 2 ms
6,940 KB
testcase_17 AC 2 ms
6,940 KB
testcase_18 AC 2 ms
6,944 KB
testcase_19 AC 5 ms
6,940 KB
testcase_20 AC 2 ms
6,944 KB
testcase_21 AC 2 ms
6,940 KB
testcase_22 AC 3 ms
6,944 KB
testcase_23 AC 1 ms
6,940 KB
testcase_24 AC 5 ms
6,940 KB
testcase_25 AC 5 ms
6,940 KB
testcase_26 AC 2 ms
6,940 KB
testcase_27 AC 3 ms
6,944 KB
testcase_28 AC 4 ms
6,944 KB
testcase_29 AC 2 ms
6,940 KB
testcase_30 AC 1 ms
6,940 KB
testcase_31 AC 1 ms
6,940 KB
testcase_32 AC 1 ms
6,944 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

package main

import "fmt"

func main() {
	var r, k, h, w, x, y int
	_, _ = fmt.Scan(&r, &k, &h, &w)

	index := func(i, j int) int { return 0 }
	switch r {
	case 0:
		x, y = h, w
		index = func(i, j int) int { return y*i + j }
	case 90:
		x, y = w, h
		index = func(i, j int) int { return y - 1 - i + y*j }
	case 180:
		x, y = h, w
		index = func(i, j int) int { return x*y - y*i - j - 1 }
	case 270:
		x, y = w, h
		index = func(i, j int) int { return y*(x-1) + i - y*j }
	}

	// 回転しながら配列に入れる
	pic := make([]int, h*w)
	var c string
	for i := 0; i < h; i++ {
		_, _ = fmt.Scan(&c)
		for j, c := range []rune(c) {
			// fmt.Println(h, w, h*w, len(pic), i, j, index(i, j))
			if c == '#' {
				k := index(i, j)
				pic[k] = 1
			}
		}
	}
	// fmt.Println(pic)

	// 拡大しながら出力
	for i := 0; i < x; i++ {
		for a := 0; a < k; a++ { // 拡大分の縦の繰り返し
			for j := 0; j < y; j++ {
				for a := 0; a < k; a++ { // 拡大分の横の繰り返し
					if pic[y*i+j] == 0 {
						fmt.Print(".")
					} else {
						fmt.Print("#")
					}
				}
			}
			fmt.Println()
		}
	}
}
0