想的时候还是要很久。。。
dp[i]=min(dp[i-1]+1,dp[k]+dp[i/k]);(2<=k<=sqrt(i),i%k==0)
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
#define N 10001
int dp[N];
int n;
int main()
{
for(int i=1;i<6;i++)
dp[i]=i;
for(int i=6;i<10001;i++)
{
dp[i]=dp[i-1]+1;
for(int j=2;j<=sqrt(i);j++)
{
if(i%j==0)
{
dp[i]=min(dp[i],dp[i/j]+dp[j]);
}
}
}
while(~scanf("%d",&n))
{
cout<<dp[n]<<endl;
}
return 0;
}