N = gets.to_i A = 10**9 + 7 dp = Array.new(N+1){ Array.new(2){ Array.new(2) { 0 } } } # i = 1 dp[1][0][0] = 0 # パ dp[1][1][0] = 1 # ケン0 dp[1][1][1] = 0 # ケン1 2.upto(N) do | i | # パ ケン0 ケン1 dp[i][0][0] = (dp[i-1][1][0] + dp[i-1][1][1]) % A # ケン0 パ dp[i][1][0] = (dp[i-1][0][0]) % A # ケン1 ケン0 dp[i][1][1] = (dp[i-1][1][0]) % A end p (dp[N][0][0] + dp[N][1][0] + dp[N][1][1]) % A