結果
| 問題 |
No.565 回転拡大
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-09-09 09:11:44 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 1,425 bytes |
| コンパイル時間 | 1,762 ms |
| コンパイル使用メモリ | 171,536 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-07 08:54:03 |
| 合計ジャッジ時間 | 2,697 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 30 |
コンパイルメッセージ
main.cpp: In function 'std::vector<std::__cxx11::basic_string<char> > Rotate(const std::vector<std::__cxx11::basic_string<char> >&, int)':
main.cpp:23:1: warning: control reaches end of non-void function [-Wreturn-type]
23 | }
| ^
ソースコード
#include <bits/stdc++.h>
using namespace std;
void print(const vector<string> & data){
for (auto &row : data) cout << row << endl;
}
vector<string> Rotate(const vector<string> & src, int R){
if (R == 0) return src;
if (R == 90){
int n_row = src.size();
int n_col = src[0].size();
vector<string> dst(n_col, string(n_row, 'x'));
for (int r = 0; r != n_row; ++r){
for (int c = 0; c != n_col; ++c){
dst[c][n_row - 1 - r] = src[r][c];
}
}
return dst;
}
if (R == 180) return Rotate(Rotate(src, 90), 90);
if (R == 270) return Rotate(Rotate(src, 180), 90);
}
vector<string> Enlarge(vector<string> src, int K){
int n_row = src.size();
int n_col = src[0].size();
vector<string> dst(n_row * K, string(n_col * K, 'x'));
for (int r = 0; r != n_row; ++r){
for (int c = 0; c != n_col; ++c){
for (int kr = 0; kr != K; ++kr){
for (int kc = 0; kc != K; ++kc){
dst[r * K + kr][c * K + kc] = src[r][c];
}
}
}
}
return dst;
}
int main() {
cin.tie(0);
ios::sync_with_stdio(false);
int R, K, H, W;
cin >> R >> K >> H >> W;
vector<string> cs(H, string());
for (auto & row : cs) cin >> row;
auto rotated = Rotate(cs, R);
auto ans = Enlarge(rotated, K);
print(ans);
return 0;
}