結果

問題 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]);
      |                 ^~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#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;
}
0