結果

問題 No.336 門松列列
コンテスト
ユーザー HIROPON87069639
提出日時 2016-02-13 15:51:51
言語 PyPy2
(7.3.20)
結果
TLE  
実行時間 -
コード長 1,059 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 167 ms
コンパイル使用メモリ 76,824 KB
最終ジャッジ日時 2025-12-03 19:20:13
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample -- * 4
other TLE * 1 -- * 7
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

# 2016.2.13
import time
N = input()
alpha = [0 for i in range(0, N)]
beta = [0 for i in range(0, N)]
start = time.time()
if N < 3:
    print "0"
else:
    flag = "alpha"
    alpha[0] = 4
    alpha[1] = 2
    beta[0] = 4
    beta[1] = 2
    for i in xrange(3, N):
        if flag == "alpha":
            for j in xrange(0, min(i-1, N/2)):
                tmp = alpha[j]
                beta[j] = 2 * tmp
            for j in xrange(0, min(i-1, N/2)):
                tmp = alpha[j]
                beta[j-1] += tmp * j
                beta[j+1] += tmp * (i - 1 - j)
            flag = "beta"
        else:
            for j in xrange(0, min(i-1, N/2)):
                tmp = beta[j]
                alpha[j] = 2 * tmp
            for j in xrange(0, min(i-1, N/2)):
                tmp = beta[j]
                alpha[j-1] += tmp * j
                alpha[j+1] += tmp * (i - 1 - j)
            flag = "alpha"
    if flag == "alpha":
        print alpha[0] % 1000000007
    else:
        print beta[0] % 1000000007
#print int((time.time() - start) * 1000),  "ms"
0