URAL_1009
其实本质只有两类数,0和非0,所以可以用f[i][0]、f[i][1]表示递推到第i位时为0以及非0的情况种数进行dp。
#include<stdio.h> #include<string.h> #define MAXD 20 int N, K; long long f[MAXD][2]; void solve() { int i, j, k; f[1][1] = K - 1, f[1][0] = 0; for(i = 2; i <= N; i ++) f[i][0] = f[i - 1][1], f[i][1] = (K - 1) * (f[i - 1][0] + f[i - 1][1]); printf("%lld\n", f[N][0] + f[N][1]); } int main() { while(scanf("%d%d", &N, &K) == 2) { solve(); } return 0; }