結果
| 問題 |
No.1084 積の積
|
| コンテスト | |
| ユーザー |
siman
|
| 提出日時 | 2022-11-29 01:41:21 |
| 言語 | Ruby (3.4.1) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 702 bytes |
| コンパイル時間 | 204 ms |
| コンパイル使用メモリ | 7,552 KB |
| 実行使用メモリ | 21,504 KB |
| 最終ジャッジ日時 | 2024-10-06 05:08:21 |
| 合計ジャッジ時間 | 5,797 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 5 |
| other | AC * 26 RE * 1 |
コンパイルメッセージ
Syntax OK
ソースコード
N = gets.to_i
A = gets.split.map(&:to_i)
L = 10 ** 9
MOD = 10 ** 9 + 7
if A.include?(0)
puts 0
exit
end
rui = Array.new(2 * N, 0)
counter = Array.new(N, 0)
l = 0
r = 0
val = A[0]
while l <= r
# pp [:l, l, :r, r]
if val >= L
len = r - l
counter[l] = len
rui[l + 1] -= 1
rui[l + len + 1] += 1
val /= A[l]
l += 1
elsif r == N - 1
len = r - l + 1
counter[l] = len
rui[l + 1] -= 1
rui[l + len + 1] += 1
val /= A[l]
l += 1
else
r += 1
val *= A[r]
end
end
# pp rui
# pp counter
ans = 1
cnt = 0
sub = 0
N.times do |i|
a = A[i]
cnt += counter[i]
sub += rui[i]
cnt += sub
ans *= a.pow(cnt, MOD)
ans %= MOD
end
puts ans
siman