CODE FESTIVAL 2016 Tournament Round 3 (Parallel)

Submission #1271189

Source codeソースコード

#include <iostream>
#include <fstream>
#include <cassert>
#include <typeinfo>
#include <vector>
#include <stack>
#include <cmath>
#include <set>
#include <map>
#include <string>
#include <algorithm>
#include <cstdio>
#include <queue>
#include <iomanip>
#include <cctype>
#include <random>
#define syosu(x) fixed<<setprecision(x)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> P;
typedef pair<double,double> pdd;
typedef pair<ll,ll> pll;
typedef vector<int> vi;
typedef vector<vi> vvi;
typedef vector<double> vd;
typedef vector<vd> vvd;
typedef vector<ll> vl;
typedef vector<vl> vvl;
typedef vector<char> vc;
typedef vector<vc> vvc;
typedef vector<string> vs;
typedef vector<bool> vb;
typedef vector<vb> vvb;
typedef vector<P> vp;
typedef vector<vp> vvp;
typedef vector<pll> vpll;
typedef pair<P,int> pip;
typedef vector<pip> vip;
const int inf=1<<29;
const ll INF=1ll<<60;
const double pi=acos(-1);
const double eps=1e-8;
const ll mod=1e9+7;
const int dx[4]={0,1,0,-1},dy[4]={1,0,-1,0};

int n,m,k;
vl a;

vl dp;

int main(){
	cin>>n>>m>>k;
	a=dp=vl(n);
	for(int i=0;i<n;i++) cin>>a[i];
	dp=a;
	for(int i=1;i<k;i++){
		deque<int> q;
		vl DP(n);
		for(int j=0;j<n;j++){
			if(j>=i) DP[j]=dp[q.front()]+a[j]*(i+1);
			while(!q.empty()&&dp[q.back()]<=dp[j]) q.pop_back();
			q.push_back(j);
			if(!q.empty()&&q.front()==j-m) q.pop_front();
		}
		dp=DP;
	}
	ll res=-1;
	for(int i=0;i<n;i++) res=max(res,dp[i]);
	cout<<res<<endl;
}

Submission

Task問題 A - ストラックアウト / Struck Out
User nameユーザ名 MAK
Created time投稿日時
Language言語 C++14 (GCC 5.4.1)
Status状態 AC
Score得点 700
Source lengthソースコード長 1546 Byte
File nameファイル名
Exec time実行時間 516 ms
Memory usageメモリ使用量 2560 KB

Test case

Set

Set name Score得点 / Max score Cases
Sample - sample_1.txt,sample_2.txt,sample_3.txt
subtask1 100 / 100 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 200 / 200 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 300 / 300 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 100 / 100 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

Test case

Case name Status状態 Exec time実行時間 Memory usageメモリ使用量
sample_1.txt AC 1 ms 256 KB
sample_2.txt AC 1 ms 256 KB
sample_3.txt AC 1 ms 256 KB
subtask_1_1.txt AC 1 ms 256 KB
subtask_1_2.txt AC 49 ms 512 KB
subtask_1_3.txt AC 482 ms 2560 KB
subtask_1_4.txt AC 6 ms 384 KB
subtask_1_5.txt AC 47 ms 2560 KB
subtask_1_6.txt AC 2 ms 256 KB
subtask_1_7.txt AC 187 ms 2560 KB
subtask_1_8.txt AC 483 ms 2560 KB
subtask_1_9.txt AC 2 ms 256 KB
subtask_2_1.txt AC 1 ms 256 KB
subtask_2_2.txt AC 1 ms 256 KB
subtask_2_3.txt AC 1 ms 256 KB
subtask_2_4.txt AC 1 ms 256 KB
subtask_2_5.txt AC 1 ms 256 KB
subtask_2_6.txt AC 1 ms 256 KB
subtask_2_7.txt AC 1 ms 256 KB
subtask_2_8.txt AC 1 ms 256 KB
subtask_2_9.txt AC 1 ms 256 KB
subtask_3_1.txt AC 84 ms 2560 KB
subtask_3_2.txt AC 84 ms 2560 KB
subtask_3_3.txt AC 83 ms 2560 KB
subtask_3_4.txt AC 68 ms 2188 KB
subtask_3_5.txt AC 5 ms 384 KB
subtask_3_6.txt AC 63 ms 2560 KB
subtask_3_7.txt AC 84 ms 2560 KB
subtask_3_8.txt AC 9 ms 512 KB
subtask_3_9.txt AC 86 ms 2560 KB
subtask_4_1.txt AC 481 ms 2560 KB
subtask_4_10.txt AC 374 ms 2560 KB
subtask_4_11.txt AC 511 ms 2560 KB
subtask_4_12.txt AC 516 ms 2560 KB
subtask_4_13.txt AC 507 ms 2560 KB
subtask_4_2.txt AC 496 ms 2560 KB
subtask_4_3.txt AC 483 ms 2560 KB
subtask_4_4.txt AC 483 ms 2560 KB
subtask_4_5.txt AC 413 ms 2560 KB
subtask_4_6.txt AC 74 ms 2560 KB
subtask_4_7.txt AC 280 ms 2560 KB
subtask_4_8.txt AC 476 ms 2560 KB
subtask_4_9.txt AC 235 ms 2560 KB