結果
問題 | No.1665 quotient replace |
ユーザー |
![]() |
提出日時 | 2022-01-04 03:56:06 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,773 bytes |
コンパイル時間 | 4,314 ms |
コンパイル使用メモリ | 254,032 KB |
最終ジャッジ日時 | 2025-01-27 08:43:46 |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | WA * 3 |
other | WA * 41 |
ソースコード
#include <bits/stdc++.h>#include <atcoder/all>using namespace std;using namespace atcoder;typedef int64_t lint;#define rep(i, n) for(int i=0; i<n; i++)#define repx(i, l, n) for(int i=l; i<n; i++)#define all(v) v.begin(), v.end()#define show(x) cout << #x << ": " << x << endl;#define list(x) cout << #x << ": " << x << " ";#define pb push_backusing vi = vector<lint>;using vvi = vector<vector<lint>>;template<class T> inline void vin(vector<T>& v) { rep(i, v.size()) cin >> v.at(i); }template<class T> inline bool chmax(T& a, T b) { if (a < b) { a = b; return 1; } return 0; }template<class T> inline bool chmin(T& a, T b) { if (a > b) { a = b; return 1; } return 0; }template<class T> inline void drop(T x) { cout << x << endl; exit(0); }template<class T> void vout(vector<T> v) { rep(i, v.size()) { cout << v.at(i) << ' '; } cout << endl; }constexpr lint LINF = LLONG_MAX/2;struct Sieve {int n;vector<lint> p;Sieve(int n=1):n(n), p(n+1) {p.at(0) = -1, p.at(1) = -1;for(lint i=2; i<=n; i++) {if(!p.at(i)) {p.at(i) = i;for(lint j=i*i; j<=n; j+=i) {if (!p.at(j)) p.at(j) = i;}}}}bool isPrime(int x) { return p.at(x) == x;}vector<lint> factorList(int x) {vector<lint> v;while (x != 1) {v.push_back(p.at(x));x /= p.at(x);}return v;}vector<lint> factor(int x) {vector<lint> v;while (x != 1) {int t = p.at(x);v.push_back(t);while (x % t == 0) x /= t;}return v;}};int main() {lint N;cin >> N;vi v(N), w(N);vin(v);lint a=0, b=0, c=0, x, y, z;Sieve S(1001001);rep(i, N) {if (v[i] == 1) continue;w[i] = S.factorList(v[i]).size();}rep(i, N) {a ^= w[i];}if (a) std::cout << "black" << '\n';else std::cout << "white" << '\n';}