結果

問題 No.754 畳み込みの和
ユーザー ducktailducktail
提出日時 2018-12-06 15:00:02
言語 Haskell
(9.8.2)
結果
AC  
実行時間 691 ms / 5,000 ms
コード長 392 bytes
コンパイル時間 1,603 ms
コンパイル使用メモリ 172,800 KB
実行使用メモリ 102,144 KB
最終ジャッジ日時 2024-09-14 02:31:34
合計ジャッジ時間 4,822 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 688 ms
102,016 KB
testcase_01 AC 691 ms
102,144 KB
testcase_02 AC 682 ms
102,144 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
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 #

import Control.Applicative
import Control.Monad

main :: IO ()
main = do
  n <- readLn
  solve <$> replicateM (n + 1) readLn <*> replicateM (n + 1) readLn >>= print

solve :: [Int] -> [Int] -> Int
solve as bs = f 0 (sum as `mod` pn) (reverse as) bs
  where
    pn = 10 ^ 9 + 7
    f sm sa (a:as) (b:bs) = f ((sm + (b * sa `mod` pn)) `mod` pn) ((sa - a) `mod` pn) as bs
    f sm sa [] [] = sm
0