結果
| 問題 |
No.1161 Many Powers
|
| ユーザー |
Konton7
|
| 提出日時 | 2020-08-18 06:08:46 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 78 ms / 2,000 ms |
| コード長 | 1,446 bytes |
| コンパイル時間 | 12,266 ms |
| コンパイル使用メモリ | 401,568 KB |
| 実行使用メモリ | 6,820 KB |
| 最終ジャッジ日時 | 2024-10-11 14:44:13 |
| 合計ジャッジ時間 | 14,264 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 23 |
コンパイルメッセージ
warning: value assigned to `ans` is never read --> src/main.rs:41:13 | 41 | let mut ans : i64 = 0; | ^^^ | = help: maybe it is overwritten before being read? = note: `#[warn(unused_assignments)]` on by default
ソースコード
use std::fs::File;
use std::io::Read;
// use std::cmp;
fn pow_speedt_with_mod(mut p: i64, mut q: i64, m: i64) -> i64 {
p %= m;
let mut r = p;
let mut ret: i64 = 1;
while q > 0 {
ret *= if q % 2 == 1 {r} else {1};
r *= r;
r %= m;
q /= 2;
ret %= m;
}
return ret;
}
fn main() {
let inputstatus = 0;
let mut buf = String::new();
let filename = "inputrust.txt";
if inputstatus == 2 {
let mut f = File::open(filename).expect("file not found");
f.read_to_string(&mut buf)
.expect("something went wrong reading the file");
} else {
std::io::stdin().read_to_string(&mut buf).unwrap();
}
let mut iter = buf.split_whitespace();
const CMAX: usize = 100000;
let a: i64 = iter.next().unwrap().parse().unwrap();
let b: i64 = iter.next().unwrap().parse().unwrap();
let c: i64 = iter.next().unwrap().parse().unwrap();
let cycle = a / c;
let modulo = a % c;
let mut ans : i64 = 0;
let mut sum1 : i64 = 0;
let mut sum2 : i64 = 0;
let mut v: [i64; CMAX] = [0; CMAX];
for i in 0..c as usize {
v[i] = pow_speedt_with_mod((i + 1) as i64, b, c) as i64;
}
for v in &v[..c as usize] {
sum1 += v;
}
sum1 %= c;
for v in &v[..modulo as usize] {
sum2 += v;
}
sum2 %= c;
ans = (sum1 * cycle + sum2) % c;
println!("{}", ans);
}
Konton7