結果
問題 | No.77 レンガのピラミッド |
ユーザー |
![]() |
提出日時 | 2016-05-15 09:24:03 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 819 bytes |
コンパイル時間 | 542 ms |
コンパイル使用メモリ | 61,996 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-06 03:10:42 |
合計ジャッジ時間 | 1,352 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 20 |
ソースコード
#include <iostream> #include <vector> using namespace std; #define rep(i, a, b) for(int i = a; i < b; i++) int main(void) { int i, j, n, tmp, sum=0, size; vector<int> a, b; cin >> n; rep(i, 0, n) { cin >> tmp; a.push_back(tmp); sum += tmp; } // aから完成形bの要素を調べる int height = 0; for (size = 0, j = 1; size + j <= sum; j += 2) { size += j; height++; } int width = j - 2; // aとbを整形する while (a.size() < width) { a.push_back(0); } while (b.size() < width) { b.push_back(0); } int as = a.size(), bs = b.size(); for (i = 0, j = 1; i < width; i++) { b[i] = j; if (i < width / 2) { j++; } else { j--; } } int x = 0; rep(i, 0, as) { if (i < bs) { if (a[i] > b[i]) x += a[i] - b[i]; } else { x += a[i]; } } cout << x << endl; }