結果
問題 | No.2 素因数ゲーム |
ユーザー |
![]() |
提出日時 | 2016-08-11 01:16:42 |
言語 | D (dmd 2.109.1) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,053 bytes |
コンパイル時間 | 832 ms |
コンパイル使用メモリ | 103,024 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-12 03:40:01 |
合計ジャッジ時間 | 1,939 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 31 |
ソースコード
import std.stdio; import std.string; import std.array; import std.typecons; import std.typetuple; import std.container; import std.algorithm; import std.conv; import std.math; import std.format; alias TypeTuple tie; void readlnToken(T...)(auto ref T args) { import std.stdio; import std.conv; import std.string; import std.array; auto line = split(readln().strip); foreach(ref arg; args) { arg = to!(typeof(arg))(line[0]); line = line[1..$]; } assert(line.empty()); // got all token?? } auto primeFactorize(T)(T n) { int[T] res; for(int i = 2; i*i <= n; ++i) { while (n%i == 0) { res[i]++; n /= i; } } if (n != 1) res[n] = 1; return res; } void solve() { long N; readlnToken(N); auto primes = primeFactorize(N); // nim int ret = 0; foreach(p,k;primes) { ret ^= k; } if ( ret ) writeln("Alice"); else writeln("Bob"); } void main() { solve(); }