acm.hdu.edu.cn/showproblem.php?pid=2709
设a[n]为和为 n 的种类数
1.n为奇数,a[n]=a[n-1]
2.n为偶数:
(1)如果加数里含1,则一定至少有两个1,即对n-2的每一个加数式后面 +1+1,总类数为a[n-2];
(2)如果加数里没有1,即对n/2的每一个加数式乘以2,总类数为a[n/2];
所以总的种类数为:a[n]=a[n-2]+a[n/2];
#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long ll;
const ll mod = 1000000000;
ll a[1000010];
int main(){
a[1] = 1, a[2] = 2;
for(int i=3; i<=1000000; i++){
if(i & 1) a[i] = a[i-1];
else a[i] = a[i-2] + a[i/2];
a[i] %= mod;
}
int n;
while(scanf("%d",&n) == 1){
printf("%I64d\n",a[n]);
}
return 0;
}