結果
| 問題 |
No.2259 Gas Station
|
| コンテスト | |
| ユーザー |
kokatsu
|
| 提出日時 | 2023-04-07 21:47:35 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 1,120 bytes |
| コンパイル時間 | 12,984 ms |
| コンパイル使用メモリ | 379,428 KB |
| 実行使用メモリ | 6,820 KB |
| 最終ジャッジ日時 | 2024-10-02 19:20:30 |
| 合計ジャッジ時間 | 14,037 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 21 |
ソースコード
fn main() {
let v: Vec<i64> = read_vec();
let l: i64 = v[0];
let r: i64 = v[1];
let c: i64 = v[2];
let d: i64 = 1_000;
let mut num: i64 = c % d;
let mut count: i64 = 0;
let mut mn: i64 = d;
let mut seen: Vec<bool> = vec![false; d as usize];
while !seen[num as usize] {
seen[num as usize] = true;
mn = mn.min((d-num)%d);
num = (num + c) % d;
count += 1;
}
if r - l >= count {
println!("{}", mn);
return;
}
let mut res: i64 = d;
num = (l * c) % d;
for _ in 0..=r-l {
res = res.min((d-num)%d);
num = (num + c) % d;
}
println!("{}", res);
}
#[allow(dead_code)]
fn read_string() -> String {
let mut s: String = String::new();
std::io::stdin().read_line(&mut s).ok();
s.trim().to_string()
}
#[allow(dead_code)]
fn read<T: std::str::FromStr>() -> T {
read_string().parse().ok().unwrap()
}
#[allow(dead_code)]
fn read_vec<T: std::str::FromStr>() -> Vec<T> {
read_string()
.split_whitespace()
.map(|v| v.parse().ok().unwrap())
.collect()
}
kokatsu