제출 #641865

#제출 시각아이디문제언어결과실행 시간메모리
641865Vanilla메기 농장 (IOI22_fish)C++17
35 / 100
1093 ms119580 KiB
#include "fish.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; ll up[3010][3010]; ll down[3010][3010]; ll s[3010][3010]; ll dp[3010]; ll max_weights(int N, int M, std::vector<int> X, std::vector<int> Y, std::vector<int> W) { for(int i=0;i<M;i++){ s[X[i]][Y[i]+1]+=W[i]; } for(int i=0;i<N;i++) for(int j=1;j<=N;j++) s[i][j]+=s[i][j-1]; for(int i=1;i<N;i++){ for(int j=0;j<=N;j++){ if(i==1) up[i][j]=s[i-1][j]; else up[i][j]=dp[i-2]+s[i-1][j]; for(int k=0;k<=j;k++) up[i][j]=max(up[i][j],up[i-1][k]-s[i-1][k]+s[i-1][j]); for(int k=j;k<=N;k++) down[i][j]=max(down[i][j],max(down[i-1][k],up[i-1][k])+s[i][k]-s[i][j]); //printf("%d %d %lld %lld\n",i,j,up[i][j],down[i][j]); dp[i]=max(dp[i],max(up[i][j],down[i][j])); } } return dp[N-1]; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...