a059. 201603_q2 矩陣轉換
Tags : APCS
Accepted rate : 5人/5人 ( 100% ) [非即時]
評分方式:
Tolerant

最近更新 : 2020-11-16 14:36

Content

原題連結

矩陣是將一群元素整齊的排列成一個矩形,在矩陣中的橫排稱為列 (row),直排稱為行 (column),其中以 Xij 來表示矩陣 X 中的第 i 列第 j行的元素。如圖一中,X32 = 6。

 

我們可以對矩陣定義兩種操作如下:

翻轉:即第一列與最後一列交換、第二列與倒數第二列交換、…依此類推。

旋轉:將矩陣以順時針方向轉 90 度。

 

例如:矩陣 X 翻轉後可得到 Y,將矩陣 Y 再旋轉後可得到 Z。

 

X                           Y                               Z  

1

4

 

3

6

 

1

2

3

2

5

 

2

5

 

4

5

6

3

6

 

1

4

 

 

 

 

圖一

 

一個矩陣 A 可以經過一連串的旋轉與翻轉操作後,轉換成新矩陣 B。如圖二中,A 經過翻轉與兩次旋轉後,可以得到 B。給定矩陣 B 和一連串的操作,請算出原始的矩陣 A。

 

翻轉                    旋轉                              旋轉

A            →                         →                                  →          B

1

1

 

2

1

 

1

1

2

 

1

1

1

3

 

1

3

 

1

3

1

 

3

1

2

1

 

1

1

 

 

 

 

 

1

2

圖二

 

 

 

Input

 

第一行有三個介於1與10之間的正整數 R, C, M。

接下來有 R 行(line)是矩陣B的內容,每一行(line)都包含 C 個正整數,其中的第 i 行第 j 個數字代表矩陣 Bij 的值。

在矩陣內容後的一行有M個整數,表示對矩陣A 進行的操作。
第 k 個整數 mk 代表第 k 個操作,如果 mk = 0 則代表旋轉,mk = 1 代表翻轉。
同一行的數字之間都是以一個空白間格,且矩陣內容為0~9的整數。

 

 

Output

輸出包含兩個部分。

第一個部分有一行,包含兩個正整數 R' 和 C',以一個空白隔開,分別代表矩陣 A 的列數和行數。

接下來有 R' 行,每一行都包含 C' 個正整數,且每一行的整數之間以一個空白隔開,其中第 i 行的第 j 個數字代表矩陣 Aij 的值。每一行的最後一個數字後並無空白。

Sample Input #1
3 2 3
1 1
3 1
1 2
1 
0 
0
Sample Output #1
3 2
1 1
1 3
2 1
測資資訊:
記憶體限制: 512 MB
公開 測資點#0 (10%): 1.0s , <1K
公開 測資點#1 (10%): 1.0s , <1K
公開 測資點#2 (10%): 1.0s , <1K
公開 測資點#3 (10%): 1.0s , <1K
公開 測資點#4 (10%): 1.0s , <1K
公開 測資點#5 (10%): 1.0s , <1K
公開 測資點#6 (10%): 1.0s , <1K
公開 測資點#7 (10%): 1.0s , <1K
公開 測資點#8 (10%): 1.0s , <1K
公開 測資點#9 (10%): 1.0s , <1K
Hint :
Tags:
APCS
出處:
[管理者: zero(管理員) ]


ID User Problem Subject Hit Post Date
沒有發現任何「解題報告」