結果

問題 No.314 ケンケンパ
コンテスト
ユーザー koyumeishi
提出日時 2015-12-07 01:02:03
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
AC  
実行時間 100 ms / 1,000 ms
コード長 623 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 347 ms
コンパイル使用メモリ 20,700 KB
実行使用メモリ 15,356 KB
最終ジャッジ日時 2026-04-04 13:55:22
合計ジャッジ時間 3,023 ms
ジャッジサーバーID
(参考情報)
judge4_0 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 17
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

n = int(input())
mat = [0,0,1,1,0,0,1,1,0]

mod = 1000000007

ret = [1,0,0,0,1,0,0,0,1]
while n>0 :
	if (n&1) == 1 :
		tmp = [0,0,0,0,0,0,0,0,0]
		for i in range(3) :
			for k in range(3) :
				for j in range(3) :
					tmp[i*3 + j] += ret[i*3 + k] * mat[k*3 + j]
					if tmp[i*3 + j] >= mod :
						tmp[i*3 + j] %= mod
		ret = tmp

	tmp_ = [0,0,0,0,0,0,0,0,0]
	for i in range(3) :
		for k in range(3) :
			for j in range(3) :
				tmp_[i*3 + j] += mat[i*3 + k] * mat[k*3 + j]
				if tmp_[i*3 + j] >= mod :
					tmp_[i*3 + j] %= mod
	mat = tmp_

	n = n>>1

ans = (ret[0*3 + 2] + ret[1*3 + 2] + ret[2*3 + 2]) % mod

print(ans)
0