#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 = 4;
int result=rec(n);
printf("数列a%dの値は%d\n", n
, result
); printf("rec関数が呼び出された回数は%d回です\n", c
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+Ci8vYXtufSA9IC02YXtuLTF9IC05YXtuLTJ9LCBhezF9PTEsIGF7Mn09Mijlho3luLDjgYLjgorniYgpCmludCBjPTA7CmludCByZWMoaW50IG4pewoJYysrOwoJaWYobj09MSl7CgkJcmV0dXJuIDE7Cgl9ZWxzZSBpZihuPT0yKXsKCQlyZXR1cm4gMjsKCX1lbHNlewoJCXJldHVybiAtNipyZWMobi0xKS05KnJlYyhuLTIpOwoJfQp9CgppbnQgbWFpbih2b2lkKSB7CiAgICBpbnQgbiA9IDQ7CiAgICBpbnQgcmVzdWx0PXJlYyhuKTsKICAgIHByaW50Zigi5pWw5YiXYSVk44Gu5YCk44GvJWRcbiIsIG4sIHJlc3VsdCk7CiAgICBwcmludGYoInJlY+mWouaVsOOBjOWRvOOBs+WHuuOBleOCjOOBn+WbnuaVsOOBryVk5Zue44Gn44GZXG4iLCBjKTsKCXJldHVybiAwOwp9Cgo=