Submission #3289137


Source Code Expand

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <string>
#include <sstream>
#include <complex>
#include <vector>
#include <list>
#include <queue>
#include <deque>
#include <stack>
#include <map>
#include <set>
using namespace std;
 
#define mod 1000000007
#define FOR(x,to) for(int x=0;x<(to);x++)
#define FORR(x,arr) for(auto& x:arr)
#define ALL(a) (a.begin()),(a.end())
#define ZERO(a) memset(a,0,sizeof(a))
#define MINUS(a) memset(a,0xff,sizeof(a))
#define long long long
inline int rei(){int x;cin>>x;return x;}
inline long rel(){long x;cin>>x;return x;}
inline string res(){string x;cin>>x;return x;}
//------------------------------------------------------- 
deque<pair<int,long>> DP[301];
long A[100000];
void Calc(){
	int N = rei();
	int M = rei();
	int K = rei();
	for(int i=0;i<N;i++){
		A[i] = rel();
	}
	long ans = 0;
	for(int i=N-1;i>=0;i--){
		for(int j=K;j>1;j--){
			while(!DP[j-1].empty()){
				if(DP[j-1].front().first > i+M){
					DP[j-1].pop_front();
				}
				else{
					break;
				}
			}
			if(!DP[j-1].empty()){
				while(!DP[j].empty() && DP[j].back().second <= DP[j-1].front().second+(K-j+1)*A[i]){
					DP[j].pop_back();
				}
				DP[j].push_back({i,DP[j-1].front().second+(K-j+1)*A[i]});
			}
		}
		{
			while(!DP[1].empty() && DP[1].back().second <= K*A[i]){
				DP[1].pop_back();
			}
			DP[1].push_back({i,K*A[i]});
		}
		if(!DP[K].empty()){
			ans = max(ans,DP[K].front().second);
		}
	}
	cout << ans << endl;
}
int main(int argc,char** argv){
	ios::sync_with_stdio(false), cin.tie(0);
	cout.tie(0); Calc(); return 0;
}

Submission Info

Submission Time
Task A - Struck Out
User leign
Language C++14 (GCC 5.4.1)
Score 700
Code Size 1678 Byte
Status AC
Exec Time 467 ms
Memory 1408 KB

Judge Result

Set Name Sample subtask1 subtask2 subtask3 All
Score / Max Score 0 / 0 100 / 100 200 / 200 300 / 300 100 / 100
Status
AC × 3
AC × 10
AC × 12
AC × 21
AC × 46
Set Name Test Cases
Sample sample_1.txt, sample_2.txt, sample_3.txt
subtask1 sample_2.txt, subtask_1_1.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt
subtask2 sample_1.txt, sample_2.txt, sample_3.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt
subtask3 sample_1.txt, sample_2.txt, sample_3.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt, subtask_3_1.txt, subtask_3_2.txt, subtask_3_3.txt, subtask_3_4.txt, subtask_3_5.txt, subtask_3_6.txt, subtask_3_7.txt, subtask_3_8.txt, subtask_3_9.txt
All sample_1.txt, sample_2.txt, sample_3.txt, sample_1.txt, sample_2.txt, sample_3.txt, subtask_1_1.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt, subtask_2_1.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt, subtask_3_1.txt, subtask_3_2.txt, subtask_3_3.txt, subtask_3_4.txt, subtask_3_5.txt, subtask_3_6.txt, subtask_3_7.txt, subtask_3_8.txt, subtask_3_9.txt, subtask_4_1.txt, subtask_4_10.txt, subtask_4_11.txt, subtask_4_12.txt, subtask_4_13.txt, subtask_4_2.txt, subtask_4_3.txt, subtask_4_4.txt, subtask_4_5.txt, subtask_4_6.txt, subtask_4_7.txt, subtask_4_8.txt, subtask_4_9.txt
Case Name Status Exec Time Memory
sample_1.txt AC 1 ms 512 KB
sample_2.txt AC 1 ms 512 KB
sample_3.txt AC 1 ms 512 KB
subtask_1_1.txt AC 1 ms 512 KB
subtask_1_2.txt AC 32 ms 512 KB
subtask_1_3.txt AC 315 ms 1280 KB
subtask_1_4.txt AC 3 ms 512 KB
subtask_1_5.txt AC 16 ms 1280 KB
subtask_1_6.txt AC 1 ms 512 KB
subtask_1_7.txt AC 109 ms 1280 KB
subtask_1_8.txt AC 318 ms 1280 KB
subtask_1_9.txt AC 2 ms 512 KB
subtask_2_1.txt AC 1 ms 512 KB
subtask_2_2.txt AC 1 ms 512 KB
subtask_2_3.txt AC 1 ms 512 KB
subtask_2_4.txt AC 1 ms 512 KB
subtask_2_5.txt AC 1 ms 512 KB
subtask_2_6.txt AC 1 ms 512 KB
subtask_2_7.txt AC 1 ms 512 KB
subtask_2_8.txt AC 1 ms 512 KB
subtask_2_9.txt AC 1 ms 512 KB
subtask_3_1.txt AC 40 ms 1280 KB
subtask_3_2.txt AC 43 ms 1280 KB
subtask_3_3.txt AC 39 ms 1280 KB
subtask_3_4.txt AC 35 ms 1152 KB
subtask_3_5.txt AC 3 ms 512 KB
subtask_3_6.txt AC 29 ms 1280 KB
subtask_3_7.txt AC 40 ms 1280 KB
subtask_3_8.txt AC 5 ms 512 KB
subtask_3_9.txt AC 47 ms 1280 KB
subtask_4_1.txt AC 316 ms 1280 KB
subtask_4_10.txt AC 467 ms 1280 KB
subtask_4_11.txt AC 383 ms 1280 KB
subtask_4_12.txt AC 386 ms 1280 KB
subtask_4_13.txt AC 382 ms 1280 KB
subtask_4_2.txt AC 374 ms 1408 KB
subtask_4_3.txt AC 315 ms 1280 KB
subtask_4_4.txt AC 316 ms 1280 KB
subtask_4_5.txt AC 275 ms 1280 KB
subtask_4_6.txt AC 34 ms 1280 KB
subtask_4_7.txt AC 202 ms 1280 KB
subtask_4_8.txt AC 311 ms 1280 KB
subtask_4_9.txt AC 155 ms 1280 KB