結果
| 問題 | No.45 回転寿司 |
| ユーザー |
|
| 提出日時 | 2015-10-12 20:57:44 |
| 言語 | F# (F# 9.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 713 bytes |
| 記録 | |
| コンパイル時間 | 15,447 ms |
| コンパイル使用メモリ | 185,364 KB |
| 実行使用メモリ | 35,468 KB |
| 最終ジャッジ日時 | 2024-11-24 10:41:07 |
| 合計ジャッジ時間 | 19,936 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 3 WA * 27 |
コンパイルメッセージ
復元対象のプロジェクトを決定しています... /home/judge/data/code/main.fsproj を復元しました (656 ms)。 MSBuild のバージョン 17.9.6+a4ecab324 (.NET) main -> /home/judge/data/code/bin/Release/net8.0/main.dll main -> /home/judge/data/code/bin/Release/net8.0/publish/
ソースコード
let rec f l p n =
if p + 3 < List.length l then
let a = (l.[p+0] + l.[p+2])
let c = (l.[p+0] + l.[p+3])
let b = (l.[p+1] + l.[p+3])
let d = List.max [a;b;c]
let e =
if d = a || d = c then 0
else 1
f l (p+2+e) (n+l.[p+e])
elif p + 2 < List.length l then
n + (max (l.[p] + l.[p+2]) l.[p+1])
elif p + 1 < List.length l then
n + (max l.[p] l.[p+1])
elif p < List.length l then
n + l.[p]
else n
stdin.ReadLine() |> ignore
let l = stdin.ReadLine().Split([|' '|]) |> Seq.map (int) |> Seq.toList
f l 0 0
|> (printfn "%d")