// yukicoder My Practice // author: Leonardone @ NEETSDKASU #include using namespace std; typedef unsigned long ul; const ul MD = 1000000007UL; // 解説読後 // http://yukicoder.me/problems/882/editorial #define arrlen(x) (sizeof(x) / sizeof((x)[0])) char str[100]; ul a[1000005] = {0, 1, 0}; ul *an = a + 3, *an2 = a + 1, *an3 = a, *end = a + 1000004; int main() { while (an != end) { *(an++) = ((*(an2++)) + (*(an3++))) % MD; } int n = 0; int k = fread(str, sizeof(char), arrlen(str), stdin); char *p = str; while (*p) { n = (n * 10) + int(*p++ - '0'); } ul r = a[n + 4], t; *(p = str + 98) = '\n'; while (r) { t = r / 10LL; *(--p) = '0' + char(r - 10LL * t); r = t; } fwrite(p, sizeof(char), str + 99 - p, stdout); return 0; }