Submission #831505

#TimeUsernameProblemLanguageResultExecution timeMemory
831505MrDebooCatfish Farm (IOI22_fish)C++17
17 / 100
1090 ms241028 KiB
#include "fish.h" #include "bits/stdc++.h" #define int long long using namespace std; int dp[311][311][311]; int vct[311][311]; int vctt[311][311]; set<int>v[311]; int N; int slv(int a,int b,int c){ if(a==N)return 0; if(dp[a][b][c]!=-1)return dp[a][b][c]; // cerr<<a<<' '<<b<<endl; int mx=0; int tot=0; for(auto &i:v[a]){ if(i<=b)tot-=vct[a][i]; if(i>max(b,c))tot+=vct[a-1][i]; tot+=vct[a+1][i]; mx=max(mx,slv(a+1,i,b)+tot); } return dp[a][b][c]=mx; } long long max_weights(int32_t n, int32_t m, std::vector<int32_t> x, std::vector<int32_t> y, std::vector<int32_t> w) { N=n; if(n>300){ int g=0; for(auto &i:w)g+=i; return g; } memset(dp,-1,sizeof dp); for(int i=0;i<=n;i++)v[i].insert(0); for(int i=0;i<m;i++){ vct[x[i]][y[i]+1]=w[i]; if(x[i])v[x[i]-1].insert(y[i]+1); v[x[i]].insert(y[i]+1); v[x[i]+1].insert(y[i]+1); } return slv(0,0,0); }
#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...