2011-12-17 00:08:43
地址:http://acm.hdu.edu.cn/showproblem.php?pid=1207
题意:中文,不说。
mark:n最大到64。dp方程很容易出,但是64的时候不好处理。用double打表知64的答案是18433,特判一下。
代码:
# include <stdio.h>
long long dp[70] = {0, 1, 3, 5} ;
long long min(long long a, long long b){return a<b?a:b;}
int main ()
{
int i, j, n ;
dp[64] = 18433 ;
for (i = 2 ; i <= 63 ; i++)
{
dp[i] = 2*dp[1]+(1LL<<(i-1))-1 ;
for (j = 2 ; j < i ; j++)
dp[i] = min(dp[i], 2 * dp[j] + (1LL<<(i-j)) - 1) ;
}
while (~scanf ("%d", &n))
printf ("%I64d\n", dp[n]) ;
return 0 ;
}