#include #define INF 0x3f3f3f3f #define rep(i,n)for(int i=0;i<(n);i++) using namespace std; int dp[1000000]; int main() { int n,c,v;scanf("%d%d%d",&n,&c,&v); memset(dp,0x3f,sizeof(dp)); dp[1]=0; for(int i=1;i<1000000;i++){ for(int j=i*2;j<1000000;j+=i)dp[j]=min(dp[j],dp[i]+c+(j/i-1)*v); } int Min=INF; for(int i=n;i<1000000;i++){ Min=min(Min,dp[i]); } printf("%d\n",Min); }