結果
| 問題 |
No.726 Tree Game
|
| コンテスト | |
| ユーザー |
特命ログイン
|
| 提出日時 | 2018-08-25 04:17:20 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 1,636 bytes |
| コンパイル時間 | 14,809 ms |
| コンパイル使用メモリ | 390,512 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-06-23 22:20:48 |
| 合計ジャッジ時間 | 16,291 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 25 |
ソースコード
use std::io::{Read, stdin};
fn main() {
let mut buf = String::new();
stdin().read_to_string(&mut buf).unwrap();
let mut tok = buf.split_whitespace();
let mut get = || tok.next().unwrap();
macro_rules! get {
($t:ty) => (get().parse::<$t>().unwrap());
() => (get!(i64));
}
let y = get!();
let x = get!();
// 2以外の素数は奇数
// 偶・偶スタートはFirstが奇数に必ず入り次Secondが偶数を選べるのでSecondの勝ち
// 奇・奇スタートはFisrtは偶数に移動するとSecondが偶数に移動し実質、偶・偶スタートなのでSecondの勝ち
// 偶・奇スタートはFirstは偶数に移動すればSecondが偶・偶スタートになるのでFirstの勝ち
// コーナーケースは 1と2
// 1・1、1・2、2・2スタートはFirstが素数へ移動しかできないのでSecondの勝ち
// 1・偶スタートは奇数か2へしか移動できないのでSecondの勝ち
// 1・奇スタートは4以上の偶数へ移動できるのでFirstの勝ち
// 2・偶スタートは奇数へしか移動できないのでSecondの勝ち
// 2・奇スタートは4以上の偶数へ移動できるのでFirstの勝ち ← 間違い!2上を移動するのでアウトSecondの勝ち
let win_first = match (x, y) {
(2,_)|(_,2) => false,
(1,p)|(p,1) if p % 2 == 0 => false,
(1,p)|(p,1) if p > 1 => true,
_ if x % 2 == y % 2 => false,
_ => true,
};
if win_first {
println!("First");
} else {
println!("Second");
}
}
特命ログイン