hackerearthで動的プログラミングの問題を解決しようとしています。 ペンと紙を使用してロジックをシミュレートした後でも、ソリューションを理解することができません(editorialに記載)。 誰かがコメント行を説明できますか?どんな助けでも大歓迎です。私はここに... 3日間のためにそれを理解するためにarray pre
をdpのロジックが混乱している
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 5e3+5;
bool vis[MAXN];
int ar[MAXN];
int pre[MAXN];
vector<int> v;
int dp[MAXN];
void sieve() {
v.push_back(2);
for(int i=3;i<MAXN;i+=2) if(!vis[i]) {
v.push_back(i);
for(int j=i*i;j<MAXN;j+=2*i) vis[j]=true;
}
}
int main() {
// freopen("TASK.in","r",stdin);
// freopen("TASK.out","w",stdout);
int n;
cin>>n;
assert(n<=5000);
for(int i=1;i<=n;i++) {
scanf("%d",&ar[i]);
assert(ar[i]<=100000);
pre[i]=pre[i-1]+ar[i];
}
sieve();
dp[0]=dp[1]=0;
for(int i=2;i<=n;i++) {
dp[i]=dp[i-1];
for(int j=0;j<(int)v.size() and v[j]<=i;j++) {
int p=i-v[j]-1;//please explain this line
if(p==-1) dp[i]=max(dp[i],pre[i]);
else dp[i]=max(dp[i],dp[p]+pre[i]-pre[p+1]);// please explain this line
}
}
cout<<dp[n]<<endl;
return 0;
}
@Josh Lee説明を必要とする部分を強調しました。説明全体を読んでいないので、保留を解除してください。 – coder
質問は合理的に自己完結型でなければなりません。あなたの質問はリンク先のページがなければ絶対に無意味です。これらのページが(一時的にまたは永久に)ダウンするとどうなりますか?他の誰かがあなたと同じ質問をしていて、Stack Overflowを検索してそれがすでに回答されているかどうかを確認しようとするとどうなりますか?誰かがネットワーク接続が制限されていて、あなたのリンクをクリックする危険がない場合はどうなりますか? – ruakh
@ks 1322は、人々がdpの質問に答えるのと同じようにdonotと思われます。 – coder