結果

問題 No.554 recurrence formula
ユーザー aimyaimy
提出日時 2017-08-12 00:05:33
言語 Haskell
(9.10.1)
結果
AC  
実行時間 40 ms / 2,000 ms
コード長 321 bytes
コンパイル時間 1,480 ms
コンパイル使用メモリ 174,464 KB
実行使用メモリ 20,736 KB
最終ジャッジ日時 2024-10-12 22:23:45
合計ジャッジ時間 2,285 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 21
権限があれば一括ダウンロードができます
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.8.2/environments/default
[1 of 2] Compiling Main             ( Main.hs, Main.o )
[2 of 2] Linking a.out

ソースコード

diff #

main = do
  n <- readLn
  print (recurrence n 1 0 1 1 `mod` modulus)

modulus = 1000000007

(*%) x y = mod (x * y) modulus

recurrence 1 _ _ _ _ = 1
recurrence n ao ae x acc
  | n == x = acc
  | odd x = recurrence n ao ((ao*%(x+1))+ae) (x+1) (ao*%(x+1))
  | otherwise = recurrence n ((ae*%(x+1))+ao) ae (x+1) (ae*%(x+1))
0