結果

問題 No.565 回転拡大
ユーザー kichirb3kichirb3
提出日時 2018-03-24 13:14:16
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 1,872 bytes
コンパイル時間 723 ms
コンパイル使用メモリ 72,232 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-07 08:47:40
合計ジャッジ時間 2,268 ms
ジャッジサーバーID
(参考情報)
judge12 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

// No.565 回転拡大
// https://yukicoder.me/problems/no/565
//

#include <iostream>
#include <vector>
#include <string>
using namespace std;

vector<vector<char>> rotate_pict(int R, vector<vector<char>> &pict);


int main() {
    std::cin.tie(nullptr);
    std::ios::sync_with_stdio(false);

    int R, K;
    cin >> R >> K;
    int H, W;
    cin >> H >> W;
    vector<vector<char>> pict(H);
    for (auto i = 0; i < H; ++i)
        pict[i].resize(W);
    for (int y = 0; y < H; ++y)
        for (int x = 0; x < W; ++x)
            cin >> pict[y][x];

    vector<vector<char>> rpict = rotate_pict(R, pict);
    for (auto y = 0; y < rpict.size(); ++y) {
        for (auto ky = 0; ky < K; ++ky) {
            for (auto x = 0; x < rpict[0].size(); ++x) {
                for (auto kx = 0; kx < K; ++kx) {
                    cout << rpict[y][x];
                }
            }
            cout << endl;
        }
    }
}


vector<vector<char>> rotate_pict(int R, vector<vector<char>> &pict) {
    int h, w;
    if (R == 90 || R == 270) {
        w = pict.size();
        h = pict[0].size();
    } else {
        h = pict.size();
        w = pict[0].size();
    }

    vector<vector<char>> rpict(h);
    for (auto i = 0; i < h; ++i)
        rpict[i].resize(w);

    for (auto y = 0; y < h; ++y) {
        for (auto x = 0; x < w; ++x) {
            switch (R) {
                case 0:
                    rpict[y][x] = pict[y][x];
                    break;
                case 180:
                    rpict[y][x] = pict[h-y-1][w-x-1];
                    break;
                case 90:
                    rpict[y][x] = pict[w-x-1][y];
                    break;
                case 270:
                    rpict[y][x] = pict[x][h-y-1];
                    break;
                default:
                    break;
            }
        }
    }
    return rpict;
}
0