結果
問題 | No.459 C-VS for yukicoder |
ユーザー |
|
提出日時 | 2016-12-10 00:27:20 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,207 bytes |
コンパイル時間 | 1,940 ms |
コンパイル使用メモリ | 177,856 KB |
実行使用メモリ | 13,440 KB |
最終ジャッジ日時 | 2024-11-28 20:58:32 |
合計ジャッジ時間 | 14,593 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 57 TLE * 1 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main() { int h, w, n; cin >> h >> w >> n; vector<int> cnt(w); for (int i = 0; i < h; i++) { char s[10001]; scanf("%s", s); for (int j = 0; j < w; j++) { if (s[j] == '#') { cnt[j]++; } } } vector<string> g(n * 3, string(3, '.')); vector<pair<int, int>> c(n); for (int i = 0; i < n; i++) { scanf("%d", &c[i].first); c[i].second = i; } sort(c.begin(), c.end()); int j = 0; for (int i = 0; i < n; i++) { while (j < c[i].first || cnt[j] == 0) { j++; } g[c[i].second * 3][j - c[i].first] = '#'; cnt[j]--; } for (int j = 0; j < w; j++) { for (int i = 0; i < n; i++) { for (int k = 0; k < 3; k++) { if (cnt[j] > 0 && c[i].first <= j && j < c[i].first + 3 && g[c[i].second * 3 + k][j - c[i].first] == '.') { g[c[i].second * 3 + k][j - c[i].first] = '#'; cnt[j]--; } } } } for (int i = 0; i < n * 3; i++) { printf("%s\n", g[i].data()); } }