結果
| 問題 |
No.77 レンガのピラミッド
|
| コンテスト | |
| ユーザー |
kapo
|
| 提出日時 | 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;
}
kapo