#include <stdio.h>
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=5;
printf("数列a%dの値は%d\n", n
, rec
(n
)); printf("このときrecの呼び出し回数は%d\n", c
);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CmludCBjID0gMDsKaW50IHJlYyhpbnQgbikgewogICAgYysrOyAKCiAgICBpZiAobiA9PSAxKXsKICAgICAgICByZXR1cm4gMTsKICAgIH0KICAgIGVsc2UgaWYgKG4gPT0gMil7CiAgICAgICAgcmV0dXJuIDI7CiAgICB9CiAgICBlbHNlewogICAgICAgIHJldHVybiAtNiAqIHJlYyhuIC0gMSkgLSA5ICogcmVjKG4gLSAyKTsKICAgIH0KfQoKaW50IG1haW4odm9pZCkgewogICAgaW50IG49NTsKICAgIHNjYW5mKCIlZCIsICZuKTsKCiAgICBwcmludGYoIuaVsOWIl2ElZOOBruWApOOBryVkXG4iLCBuLCByZWMobikpOwogICAgcHJpbnRmKCLjgZPjga7jgajjgY1yZWPjga7lkbzjgbPlh7rjgZflm57mlbDjga8lZFxuIiwgYyk7CgogICAgcmV0dXJuIDA7Cn0=