結果
| 問題 |
No.3050 Prefix Removal
|
| コンテスト | |
| ユーザー |
pengin_2000
|
| 提出日時 | 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;
}
pengin_2000