結果
| 問題 |
No.281 門松と魔法(1)
|
| コンテスト | |
| ユーザー |
tottoripaper
|
| 提出日時 | 2015-09-28 21:47:07 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,570 bytes |
| コンパイル時間 | 233 ms |
| コンパイル使用メモリ | 36,704 KB |
| 実行使用メモリ | 6,824 KB |
| 最終ジャッジ日時 | 2024-11-06 19:43:03 |
| 合計ジャッジ時間 | 1,659 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 55 WA * 2 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:11:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
11 | scanf("%d", &d);
| ~~~~~^~~~~~~~~~
main.cpp:12:31: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
12 | for(int i=0;i<3;i++){scanf("%d", H+i);}
| ~~~~~^~~~~~~~~~~
ソースコード
#include <cstdio>
#include <algorithm>
#include <limits>
int d;
int H[3];
const int INF = std::numeric_limits<int>::max();
int main(){
scanf("%d", &d);
for(int i=0;i<3;i++){scanf("%d", H+i);}
if(d == 0){
puts((H[0] == H[1] || H[1] == H[2] || H[2] == H[0])
? "-1"
: "0");
return 0;
}
int res = INF;
// 中央の木を最大にしたい
{
int s = std::max((H[0] - H[1] + d - 1) / d, 0),
t = std::max((H[2] - H[1] + d - 1) / d, 0);
int a = std::max(H[0] - s * d, 0),
b = std::max(H[2] - t * d, 0);
if(a == H[1]){a = std::max(a - d, 0); s += 1;}
if(b == H[1]){b = std::max(b - d, 0); t += 1;}
if(a != b){
res = s + t;
}else if(!(a == 0 && b == 0)){
res = s + t + 1;
}
}
// printf("1st: %d\n", res);
// 中央の木を最小にしたい
{
int count = 0;
if(H[0] == H[2]){
H[0] = std::max(H[0] - d, 0);
count += 1;
}
int t = std::max({ (H[1] - H[0] + d - 1) / d
, (H[1] - H[2] + d - 1) / d
, 0
} );
int x = std::max(H[1] - t * d, 0);
if(x == H[0] || x == H[2]){
x = std::max(x - d, 0);
count += 1;
}
if(!((H[0] == 0 || H[2] == 0) && x == 0)){
res = std::min(res, t + count);
}
}
printf("%d\n", (res == INF) ? -1 : res);
}
tottoripaper