結果
問題 | No.1665 quotient replace |
ユーザー |
|
提出日時 | 2021-09-03 23:06:49 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 400 ms / 3,000 ms |
コード長 | 826 bytes |
コンパイル時間 | 1,902 ms |
コンパイル使用メモリ | 168,544 KB |
実行使用メモリ | 11,212 KB |
最終ジャッジ日時 | 2024-12-15 17:09:48 |
合計ジャッジ時間 | 8,513 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 41 |
ソースコード
#include <bits/stdc++.h> //#include<atcoder/all> using namespace std; //using namespace atcoder; using ll = long long; #define all(A) A.begin(),A.end() using vll = vector<ll>; #define rep(i, n) for (long long i = 0; i < (long long)(n); i++) using Graph = vector<vector<ll>>; int main() { vector<ll> P(1e6+10, -1); rep(i, 1e6 + 10) { P[i] = i; } P[0] = P[1] = -1; rep(p, 1e6 + 10) { if (P[p]==p) { for (ll j = p + p; j <= 1e6 + 4; j += p) { if(P[j]==j)P[j] = p; } } } ll N; cin >> N; ll AN = 0; rep(i, N) { ll A; cin >> A; ll k = 0; while (A != 1) { A /= P[A]; k++; } AN = AN ^ k; } cout << (AN== 0 ? "black" : "white") << endl; }