#include #include #include #include #include #include #include #include #include #include #include #include using namespace std; #define rep(i,j,n) for(int i=(j);i<(n);++i) #define erep(i,j,n) for(int i=(j);i<=(n);++i) #define all(i) i.begin(),i.end() #define rall(i) i.rbegin(),i.rend() #define INF 1e9 const int mod = 1e9 + 7; typedef vector vi; typedef vector> vvi; typedef vector vs; typedef vector> vvs; typedef pair pi; typedef long long i64; int main() { int n; cin >> n; vector> dp(n + 1, vector(3, 0)); dp[1][1] = 1; rep(i, 1, n) { dp[i + 1][0] = (dp[i][1] + dp[i][2]) % mod; dp[i + 1][1] = dp[i][0] % mod; dp[i + 1][2] = dp[i][1] % mod; } cout << (dp[n][0] + dp[n][1] + dp[n][2]) % mod << endl; }