結果

問題 No.307 最近色塗る問題多くない?
ユーザー 小指が強い人小指が強い人
提出日時 2015-11-27 23:41:39
言語 C++11
(gcc 13.3.0)
結果
TLE  
実行時間 -
コード長 1,014 bytes
コンパイル時間 746 ms
コンパイル使用メモリ 63,072 KB
実行使用メモリ 13,896 KB
最終ジャッジ日時 2024-09-14 01:02:30
合計ジャッジ時間 6,633 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 8 TLE * 1 -- * 27
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
#include <string>
using namespace std;
#define REP(i, n) for(int i = 0; i < n; i++)
int w = 0;
int h = 0;
vector<vector<int> > v;
int dx[] = {1, 0, -1, 0};
int dy[] = {0, 1, 0, -1};
void paint(int cx, int cy, int q)
{
    if(v[cy][cx] == q)
        return;
    v[cy][cx] = q;
    REP(i, 4)
    {
        int tx = cx + dx[i];
        int ty = cy + dy[i];
        if(tx < 0 || tx >= w || ty < 0 || ty >= h)
            continue;
        paint(tx, ty, q);
    }
}

int main(void)
{
    cin >> h;
    cin >> w;
    v.resize(h);
    REP(i, h)
        REP(j, w)
        {
            int p;
            cin >> p;
            v[i].push_back(p);
        }
    int n;
    cin >> n;
    REP(i, n)
    {
        int r, c, x;
        cin >> r >> c >> x;
        r--; c--;
        paint(c, r, x);
    }
    REP(i, h)
    {
        REP(j, w)
        {
            cout << v[i][j];
            if(j < w - 1)
                cout << " ";
        } 
        cout << endl;
    }
    return 0;
}
0