結果
問題 |
No.3050 Prefix Removal
|
ユーザー |
![]() |
提出日時 | 2025-03-07 22:32:34 |
言語 | C (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 818 bytes |
コンパイル時間 | 1,201 ms |
コンパイル使用メモリ | 26,240 KB |
実行使用メモリ | 13,356 KB |
最終ジャッジ日時 | 2025-03-07 22:32:42 |
合計ジャッジ時間 | 6,714 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 10 WA * 45 |
コンパイルメッセージ
main.c: In function ‘main’: main.c:8:9: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 8 | scanf("%lld %lld", &n, &k); | ^~~~~~~~~~~~~~~~~~~~~~~~~~ main.c:11:17: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 11 | scanf("%lld", &a[i]); | ^~~~~~~~~~~~~~~~~~~~
ソースコード
#include<stdio.h> long long int a[500005]; long long int sum[500005]; long long int q[500005], l, r; int main() { long long int n, k; scanf("%lld %lld", &n, &k); long long int i, j; for (i = 0; i < n; i++) scanf("%lld", &a[i]); sum[0] = 0; for (i = 0; i < n; i++) sum[i + 1] = sum[i] + a[i]; long long int m, val = -1e18; j = k - 1; for (i = k; i <= n; i++) { if (val < sum[i] - sum[j]) { m = i; val = sum[i] - sum[j]; } if (sum[i] < sum[j]) j = i; } n = m; long long int ans = 0; l = r = 0; for (j = n - 1, i = k - 1; i > 0; i--) { for (; j >= i; j--) { q[r] = j; while (l<r && sum[q[r - 1]]>sum[q[r]]) { r--; q[r] = q[r + 1]; } r++; } ans += (sum[n] - sum[q[l]]) * (i + 1); n = q[l]; l++; } ans += sum[n]; printf("%lld\n", ans); return 0; }