답안 #1004252

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1004252 2024-06-21T06:49:23 Z 0pt1mus23 말 (IOI15_horses) C++14
17 / 100
1500 ms 24344 KB
#include "horses.h"
#include <bits/stdc++.h>
using namespace std;
#define ins insert
#define pb push_back
#define pii pair<int, int>
#define endl '\n'
#define drop(x) cout<<(x)<<endl; return;
#define all(x) x.begin(),x.end()
const int mod = 1e9 +7, sze = 5*1e5, prime = 23;
const int inf = INT_MAX;
int arr[sze],brr[sze];
int n;

const int dse = 1e3; 
int dp[dse+1][dse+1];
map<int,int> dp2[dse+1];
int func(){
	int ans=0;
	if(n<=0){
		for(int i=0;i<=n;i++){
			for(int j=0;j<=dse;j++){
				dp[i][j]=-1;
			}
		}
		dp[0][1]=0;
		for(int i=0;i<n;i++){
			for(int j=1;j<=dse;j++){
				if(dp[i][j]!=-1){
					int y =j * arr[i]; 
					// cout<<i<<" "<<j<<" "<<dp[i][j]<<endl;
					for(int k=0;k<=y;k++){
						/*if(k>dse){
							return 17;
						}*/
						dp[i+1][ y-k ] = (max( dp[i+1][y-k], (dp[i][j] + (k)* brr[i] ) %mod));
					}
				}

			}
		}
		for(int i=0;i<=n;i++){
			for(int j=0;j<=dse;j++){
				ans=max(ans,( dp[i][j] )%mod);
			}
		}
	}
	else{
		for(int i =0;i<=n;i++){
			dp2[i]=map<int,int>();
		}
		dp2[0][1]=0;
		for(int i=0;i<n;i++){
			for(auto v:dp2[i]){
				int y =v.first * arr[i]; 
				// cout<<i<<" "<<j<<" "<<dp[i][j]<<endl;
				for(int k=0;k<=y;k++){
					/*if(k>dse){
						return 17;
					}*/
					dp2[i+1][ y-k ] = (max( dp2[i+1][y-k], (v.second + (k)* brr[i] ) %mod));
				}

			}
		}
		for(int i=0;i<=n;i++){
			for(auto v:dp2[i]){
				// cout<<i<<" "<<v.second<<endl;
				ans=max(ans,( v.second )%mod);
			}
		}
	}
	return ans;
}

int init(int N, int X[], int Y[]) {
	n=N;
	for(int i=0;i<n;i++){
		arr[i]=X[i];
		brr[i]=Y[i];
	}
	return func();
}

int updateX(int pos, int val) {	
	arr[pos]=val;
	return func();
}

int updateY(int pos, int val) {
	brr[pos]=val;
	return func();
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Correct 11 ms 592 KB Output is correct
3 Correct 69 ms 700 KB Output is correct
4 Correct 0 ms 344 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 78 ms 748 KB Output is correct
8 Correct 77 ms 848 KB Output is correct
9 Correct 1 ms 348 KB Output is correct
10 Correct 0 ms 348 KB Output is correct
11 Correct 0 ms 348 KB Output is correct
12 Correct 0 ms 348 KB Output is correct
13 Correct 2 ms 348 KB Output is correct
14 Correct 0 ms 348 KB Output is correct
15 Correct 0 ms 348 KB Output is correct
16 Correct 33 ms 564 KB Output is correct
17 Correct 0 ms 348 KB Output is correct
18 Correct 0 ms 348 KB Output is correct
19 Correct 0 ms 348 KB Output is correct
20 Correct 12 ms 596 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Correct 14 ms 576 KB Output is correct
3 Correct 69 ms 808 KB Output is correct
4 Correct 0 ms 344 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 73 ms 848 KB Output is correct
8 Correct 74 ms 852 KB Output is correct
9 Correct 0 ms 348 KB Output is correct
10 Correct 0 ms 348 KB Output is correct
11 Correct 0 ms 348 KB Output is correct
12 Correct 0 ms 348 KB Output is correct
13 Correct 2 ms 348 KB Output is correct
14 Correct 0 ms 348 KB Output is correct
15 Correct 0 ms 348 KB Output is correct
16 Correct 32 ms 600 KB Output is correct
17 Correct 1 ms 348 KB Output is correct
18 Correct 0 ms 348 KB Output is correct
19 Correct 0 ms 348 KB Output is correct
20 Correct 22 ms 604 KB Output is correct
21 Execution timed out 1568 ms 1716 KB Time limit exceeded
22 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 20 ms 24344 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Correct 14 ms 604 KB Output is correct
3 Correct 76 ms 712 KB Output is correct
4 Correct 0 ms 344 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 93 ms 712 KB Output is correct
8 Correct 82 ms 932 KB Output is correct
9 Correct 0 ms 348 KB Output is correct
10 Correct 0 ms 600 KB Output is correct
11 Correct 0 ms 348 KB Output is correct
12 Correct 0 ms 348 KB Output is correct
13 Correct 2 ms 348 KB Output is correct
14 Correct 0 ms 348 KB Output is correct
15 Correct 0 ms 348 KB Output is correct
16 Correct 35 ms 604 KB Output is correct
17 Correct 0 ms 348 KB Output is correct
18 Correct 0 ms 348 KB Output is correct
19 Correct 0 ms 344 KB Output is correct
20 Correct 13 ms 584 KB Output is correct
21 Execution timed out 1569 ms 1956 KB Time limit exceeded
22 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Correct 14 ms 548 KB Output is correct
3 Correct 77 ms 644 KB Output is correct
4 Correct 0 ms 344 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 80 ms 852 KB Output is correct
8 Correct 77 ms 848 KB Output is correct
9 Correct 0 ms 348 KB Output is correct
10 Correct 0 ms 348 KB Output is correct
11 Correct 0 ms 348 KB Output is correct
12 Correct 0 ms 348 KB Output is correct
13 Correct 2 ms 348 KB Output is correct
14 Correct 0 ms 348 KB Output is correct
15 Correct 0 ms 348 KB Output is correct
16 Correct 34 ms 684 KB Output is correct
17 Correct 0 ms 348 KB Output is correct
18 Correct 0 ms 348 KB Output is correct
19 Correct 0 ms 348 KB Output is correct
20 Correct 13 ms 604 KB Output is correct
21 Execution timed out 1542 ms 1732 KB Time limit exceeded
22 Halted 0 ms 0 KB -