P14644题解
思路
发现
具体地说,对于
如果是加则
如果是乘则
然后直接记忆化搜索即可,当然你也可以打 DP。时间复杂度
代码
#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int N=3003;
int n,a,b,c;
ll f[N];
ll dfs(int x){
if(x==1)return a;
if(f[x])return f[x];
f[x]=1e18;
for(int i=1;i<=x/2;i++)f[x]=min(f[x],dfs(i)+dfs(x-i)+b);
for(int i=2;i*i<=x;i++)if(x%i==0)f[x]=min(f[x],dfs(i)+dfs(x/i)+c);
return f[x];
}
int main(){
cin.tie(0)->sync_with_stdio(0);
cin>>n>>a>>b>>c;
for(int i=1;i<=n;i++)cout<<dfs(i)<<' ';
}