結果
| 問題 |
No.1237 EXP Multiple!
|
| コンテスト | |
| ユーザー |
どらら
|
| 提出日時 | 2020-09-26 02:40:23 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,062 bytes |
| コンパイル時間 | 12,890 ms |
| コンパイル使用メモリ | 377,860 KB |
| 実行使用メモリ | 5,632 KB |
| 最終ジャッジ日時 | 2024-06-28 11:12:55 |
| 合計ジャッジ時間 | 14,584 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 18 WA * 1 |
ソースコード
use std::io::*;
use std::str::FromStr;
fn fact(x: i128) -> i128 {
let mut ret = 1;
for i in 1..=x {
ret *= i;
}
ret
}
fn calc(n: i64, v: Vec<i64>) -> i64 {
let mut ret: i128 = 1;
for i in 0..n {
let x = v[i as usize] as i128;
if x == 0 {
return -1;
}
if x >= 4 {
return 1000_000_007_i64;
}
let mut p = 1;
for _ in 0..fact(x) {
p *= x;
}
ret *= p;
if ret >= 1000_000_007_i128 {
return 1000_000_007_i64;
}
}
(1000_000_007_i128 % ret) as i64
}
fn main() {
let mut s = String::new();
stdin().read_line(&mut s).ok();
let mut itr = s.split_whitespace().map(|x| i64::from_str(x).unwrap());
let n = itr.next().unwrap();
s.clear();
stdin().read_line(&mut s).ok();
let mut itr = s.split_whitespace().map(|x| i64::from_str(x).unwrap());
let mut v = Vec::new();
for _i in 0..n {
v.push(itr.next().unwrap());
}
println!("{}", calc(n, v));
}
どらら