#include <stdio.h>
//a{n} = -6a{n-1} -9a{n-2}, a{1}=1, a{2}=2(再帰あり版)
int c = 0;
int rec(int n){
c++;
if(n == 1){
return 1;
}
else if(n == 2){
return 2;
}
else{
return -6*rec(n-1) -9*rec(n-2);
}
}
int main(void) {
int n;
int value = rec(n);
printf("数列a%dの値は%d\n", n
, value
); printf("このときrecの呼び出し回数は%d\n", c
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+Ci8vYXtufSA9IC02YXtuLTF9IC05YXtuLTJ9LCBhezF9PTEsIGF7Mn09Mijlho3luLDjgYLjgorniYgpCmludCBjID0gMDsKaW50IHJlYyhpbnQgbil7CgljKys7CglpZihuID09IDEpewoJCXJldHVybiAxOwoJfQogICAgZWxzZSBpZihuID09IDIpewogICAgCXJldHVybiAyOwogICAgfQogICAgZWxzZXsKICAgIAlyZXR1cm4gLTYqcmVjKG4tMSkgLTkqcmVjKG4tMik7CiAgICB9Cn0KCmludCBtYWluKHZvaWQpIHsKICAgIGludCBuOyAKICAgIHNjYW5mKCIlZCIsICZuKTsKICAgIGludCB2YWx1ZSA9IHJlYyhuKTsKICAgIHByaW50Zigi5pWw5YiXYSVk44Gu5YCk44GvJWRcbiIsIG4sIHZhbHVlKTsKICAgIHByaW50Zigi44GT44Gu44Go44GNcmVj44Gu5ZG844Gz5Ye644GX5Zue5pWw44GvJWRcbiIsIGMpOwoJcmV0dXJuIDA7Cn0KCg==