杭电-------2045不容易系列之(3)—— LELE的RPG难题(C语言写)

/*

当最后一个块可以和第一个块染相同颜色时,答案为:3*pow(2,n-1);但是最后一块不能和第一块颜色相同,则减去和第一

块颜色相同的染色种数即可    3*pow(2,n-1)-ranse(n-1)

*/

#include<stdio.h>
#include<math.h>
long long a[50] = { 0 };

long long ditui(int n) {
    if (n < 3 || a[n]>0) {
        return a[n];
    }
    return a[n] = 3 * pow(2, n - 1) - ditui(n - 1);
}

int main() {
    int m;
    a[1] = 3;
    a[2] = 6;
    while (~scanf("%d", &m)) {
        printf("%lld\n", ditui(m));
    }
    return 0;

}

 

posted @ 2018-02-01 15:31  Carol淋  阅读(203)  评论(0编辑  收藏  举报