結果
| 問題 |
No.343 手抜き工事のプロ
|
| コンテスト | |
| ユーザー |
FF256grhy
|
| 提出日時 | 2015-08-04 17:54:31 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,043 bytes |
| コンパイル時間 | 173 ms |
| コンパイル使用メモリ | 23,296 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-07-18 01:16:44 |
| 合計ジャッジ時間 | 1,194 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 22 WA * 5 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:15:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
15 | scanf("%d%d", &n, &l);
| ~~~~~^~~~~~~~~~~~~~~~
main.cpp:24:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
24 | scanf("%d", &x[i]);
| ~~~~~^~~~~~~~~~~~~
ソースコード
// 想定WA
#include <stdio.h>
#define MAX_N 100000
#define MAX_L 10000
#define MAX_X 5000
int n, l, x[MAX_N], sum[MAX_N];
int abs(int a) { return 0 < a ? a : -a; }
int main(void) {
int i;
scanf("%d%d", &n, &l);
// assert
if( ! ( 1 <= n && n <= MAX_N ) ) { return 0; }
if( ! ( 1 <= l && l <= MAX_L ) ) { return 0; }
// 色々と面倒なので, x[i] には上から i 番目を入れる
x[n - 1] = 0;
for(i = n - 2; 0 <= i; i--) {
scanf("%d", &x[i]);
// assert
if( ! ( abs( x[i] ) <= MAX_X ) ) { return 0; }
}
// sum[i] は i より上の座標の和, i より上の重心座標は sum[i]/i
sum[0] = 0;
for(i = 1; i < n; i++) {
sum[i] = sum[i - 1] + x[i - 1];
}
int counter = 0;
for(i = 1; i < n; i++) {
if( l <= abs(x[i - 1] - x[i]) ) { counter = -1; break; }
if(
// l/2 <= abs( sum[i]/i - x[i] ) の両辺に 2 を掛けるだけだとダメ
l <= abs( 2 * sum[i] / i - 2 * x[i] ) ||
l <= abs( 2 * sum[i] / i - 2 * x[i - 1] )
) { counter++; }
}
printf("%d\n", counter);
return 0;
}
FF256grhy