結果
問題 |
No.1237 EXP Multiple!
|
ユーザー |
![]() |
提出日時 | 2023-09-12 15:38:22 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 720 bytes |
コンパイル時間 | 167 ms |
コンパイル使用メモリ | 82,632 KB |
実行使用メモリ | 107,572 KB |
最終ジャッジ日時 | 2024-06-30 03:34:24 |
合計ジャッジ時間 | 21,665 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 14 RE * 5 |
ソースコード
# オイラーの小定理とかではない # 問題文よく読むと、mod 10**9+7を計算式で割る、いつもの逆 # ということは計算式がmodを超えたら答えは常にmod # 実験するとすぐわかるがaが4以上でmodを超える from math import factorial mod = 10**9+7 N = int(input()) A = list(map(int, input().split())) A.sort() denominator = 1 ans_flag = False for i in range(N): if A[i]<=3: calc = pow(A[i], factorial(A[i])) denominator *= calc if denominator > mod: ans_flag = True break else: ans_flag = True break if ans_flag == True: print(mod) else: ans = mod%denominator print(ans)