結果
| 問題 |
No.988 N×Mマス計算(総和)
|
| コンテスト | |
| ユーザー |
norioc
|
| 提出日時 | 2024-11-12 05:06:14 |
| 言語 | Elixir (1.18.1) |
| 結果 |
AC
|
| 実行時間 | 1,454 ms / 2,000 ms |
| コード長 | 904 bytes |
| コンパイル時間 | 1,218 ms |
| コンパイル使用メモリ | 62,948 KB |
| 実行使用メモリ | 92,352 KB |
| 最終ジャッジ日時 | 2024-11-12 05:06:39 |
| 合計ジャッジ時間 | 24,259 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 19 |
ソースコード
defmodule Main do
def input, do: IO.read(:line) |> String.trim
def ii, do: input() |> String.to_integer
def li, do: input() |> String.split |> Enum.map(&String.to_integer/1)
def yn(b), do: IO.puts (if b, do: "Yes", else: "No")
def f("+", a, b, mod) do
na = length(a)
nb = length(b)
sa = rem(Enum.sum(a), mod)
sb = rem(Enum.sum(b), mod)
rem(sa*nb + sb*na, mod)
end
def f("*", a, b, mod) do
sa = rem(Enum.sum(a), mod)
sb = rem(Enum.sum(b), mod)
rem(sa * sb, mod)
end
def main do
{_ok, s} = File.read("/dev/stdin")
ss = s |> String.trim() |> String.split("\n")
[_n, _m, k] = hd(ss) |> String.split() |> Enum.map(&String.to_integer/1)
s = hd(tl(ss)) |> String.split()
op = hd(s)
b = tl(s) |> Enum.map(&String.to_integer/1)
a = tl(tl(ss)) |> Enum.map(&String.to_integer/1)
ans = f(op, a, b, k)
IO.puts ans
end
end
norioc