QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#304628 | #8004. Bit Component | ucup-team180# | AC ✓ | 11ms | 8424kb | C++20 | 33.5kb | 2024-01-13 22:10:48 | 2024-01-13 22:10:48 |
Judging History
answer
#pragma region Macros
#ifdef noimi
#include "my_template.hpp"
#else
#pragma GCC target("avx2")
#pragma GCC optimize("O3")
#pragma GCC optimize("unroll-loops")
#include <immintrin.h>
#include <algorithm>
#include <array>
#include <bitset>
#include <cassert>
#include <cctype>
#include <cfenv>
#include <cfloat>
#include <chrono>
#include <cinttypes>
#include <climits>
#include <cmath>
#include <complex>
#include <cstdarg>
#include <cstddef>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <deque>
#include <fstream>
#include <functional>
#include <immintrin.h>
#include <initializer_list>
#include <iomanip>
#include <ios>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <stack>
#include <streambuf>
#include <string>
#include <tuple>
#include <type_traits>
#include <utility>
#include <variant>
#ifdef noimi
#define oj_local(a, b) b
#else
#define oj_local(a, b) a
#endif
#define LOCAL if(oj_local(0, 1))
#define OJ if(oj_local(1, 0))
using namespace std;
using ll = long long;
using ull = unsigned long long int;
using i128 = __int128_t;
using pii = pair<int, int>;
using pll = pair<ll, ll>;
using ld = long double;
template <typename T> using vc = vector<T>;
template <typename T> using vvc = vector<vc<T>>;
template <typename T> using vvvc = vector<vvc<T>>;
using vi = vc<int>;
using vl = vc<ll>;
using vpi = vc<pii>;
using vpl = vc<pll>;
template <class T> using pq = priority_queue<T>;
template <class T> using pqg = priority_queue<T, vector<T>, greater<T>>;
template <typename T> int si(const T &x) { return x.size(); }
template <class T, class S> inline bool chmax(T &a, const S &b) { return (a < b ? a = b, 1 : 0); }
template <class T, class S> inline bool chmin(T &a, const S &b) { return (a > b ? a = b, 1 : 0); }
vi iota(int n) {
vi a(n);
return iota(a.begin(), a.end(), 0), a;
}
template <typename T> vi iota(const vector<T> &a, bool greater = false) {
vi res(a.size());
iota(res.begin(), res.end(), 0);
sort(res.begin(), res.end(), [&](int i, int j) {
if(greater) return a[i] > a[j];
return a[i] < a[j];
});
return res;
}
// macros
#define overload5(a, b, c, d, e, name, ...) name
#define overload4(a, b, c, d, name, ...) name
#define endl '\n'
#define REP0(n) for(ll jidlsjf = 0; jidlsjf < n; ++jidlsjf)
#define REP1(i, n) for(ll i = 0; i < (n); ++i)
#define REP2(i, a, b) for(ll i = (a); i < (b); ++i)
#define REP3(i, a, b, c) for(ll i = (a); i < (b); i += (c))
#define rep(...) overload4(__VA_ARGS__, REP3, REP2, REP1, REP0)(__VA_ARGS__)
#define per0(n) for(int jidlsjf = 0; jidlsjf < (n); ++jidlsjf)
#define per1(i, n) for(ll i = (n)-1; i >= 0; --i)
#define per2(i, a, b) for(ll i = (a)-1; i >= b; --i)
#define per3(i, a, b, c) for(ll i = (a)-1; i >= (b); i -= (c))
#define per(...) overload4(__VA_ARGS__, per3, per2, per1, per0)(__VA_ARGS__)
#define fore0(a) rep(a.size())
#define fore1(i, a) for(auto &&i : a)
#define fore2(a, b, v) for(auto &&[a, b] : v)
#define fore3(a, b, c, v) for(auto &&[a, b, c] : v)
#define fore4(a, b, c, d, v) for(auto &&[a, b, c, d] : v)
#define fore(...) overload5(__VA_ARGS__, fore4, fore3, fore2, fore1, fore0)(__VA_ARGS__)
#define setbits(j, n) for(ll iiiii = (n), j = lowbit(iiiii); iiiii; iiiii ^= 1 << j, j = lowbit(iiiii))
#define perm(v) for(bool permrepflag = true; (permrepflag ? exchange(permrepflag, false) : next_permutation(all(v)));)
#define fi first
#define se second
#define pb push_back
#define ppb pop_back
#define ppf pop_front
#define eb emplace_back
#define drop(s) cout << #s << endl, exit(0)
#define si(c) (int)(c).size()
#define lb(c, x) distance((c).begin(), lower_bound(all(c), (x)))
#define lbg(c, x) distance((c).begin(), lower_bound(all(c), (x), greater{}))
#define ub(c, x) distance((c).begin(), upper_bound(all(c), (x)))
#define ubg(c, x) distance((c).begin(), upper_bound(all(c), (x), greater{}))
#define rng(v, l, r) v.begin() + (l), v.begin() + (r)
#define all(c) begin(c), end(c)
#define rall(c) rbegin(c), rend(c)
#define SORT(v) sort(all(v))
#define REV(v) reverse(all(v))
#define UNIQUE(x) SORT(x), x.erase(unique(all(x)), x.end())
template <typename T = ll, typename S> T SUM(const S &v) { return accumulate(all(v), T(0)); }
#define MIN(v) *min_element(all(v))
#define MAX(v) *max_element(all(v))
#define overload2(_1, _2, name, ...) name
#define vec(type, name, ...) vector<type> name(__VA_ARGS__)
#define vv(type, name, h, ...) vector<vector<type>> name(h, vector<type>(__VA_ARGS__))
#define vvv(type, name, h, w, ...) vector<vector<vector<type>>> name(h, vector<vector<type>>(w, vector<type>(__VA_ARGS__)))
#define vvvv(type, name, a, b, c, ...) \
vector<vector<vector<vector<type>>>> name(a, vector<vector<vector<type>>>(b, vector<vector<type>>(c, vector<type>(__VA_ARGS__))))
constexpr pii dx4[4] = {pii{1, 0}, pii{0, 1}, pii{-1, 0}, pii{0, -1}};
constexpr pii dx8[8] = {{1, 0}, {1, 1}, {0, 1}, {-1, 1}, {-1, 0}, {-1, -1}, {0, -1}, {1, -1}};
namespace yesno_impl {
const string YESNO[2] = {"NO", "YES"};
const string YesNo[2] = {"No", "Yes"};
const string yesno[2] = {"no", "yes"};
const string firstsecond[2] = {"second", "first"};
const string FirstSecond[2] = {"Second", "First"};
const string possiblestr[2] = {"impossible", "possible"};
const string Possiblestr[2] = {"Impossible", "Possible"};
void YES(bool t = 1) { cout << YESNO[t] << endl; }
void NO(bool t = 1) { YES(!t); }
void Yes(bool t = 1) { cout << YesNo[t] << endl; }
void No(bool t = 1) { Yes(!t); }
void yes(bool t = 1) { cout << yesno[t] << endl; }
void no(bool t = 1) { yes(!t); }
void first(bool t = 1) { cout << firstsecond[t] << endl; }
void First(bool t = 1) { cout << FirstSecond[t] << endl; }
void possible(bool t = 1) { cout << possiblestr[t] << endl; }
void Possible(bool t = 1) { cout << Possiblestr[t] << endl; }
}; // namespace yesno_impl
using namespace yesno_impl;
#define INT(...) \
int __VA_ARGS__; \
IN(__VA_ARGS__)
#define INTd(...) \
int __VA_ARGS__; \
IN2(__VA_ARGS__)
#define LL(...) \
ll __VA_ARGS__; \
IN(__VA_ARGS__)
#define LLd(...) \
ll __VA_ARGS__; \
IN2(__VA_ARGS__)
#define STR(...) \
string __VA_ARGS__; \
IN(__VA_ARGS__)
#define CHR(...) \
char __VA_ARGS__; \
IN(__VA_ARGS__)
#define DBL(...) \
double __VA_ARGS__; \
IN(__VA_ARGS__)
#define VEC(type, name, size) \
vector<type> name(size); \
IN(name)
#define VECd(type, name, size) \
vector<type> name(size); \
IN2(name)
#define VEC2(type, name1, name2, size) \
vector<type> name1(size), name2(size); \
for(int i = 0; i < size; i++) IN(name1[i], name2[i])
#define VEC2d(type, name1, name2, size) \
vector<type> name1(size), name2(size); \
for(int i = 0; i < size; i++) IN2(name1[i], name2[i])
#define VEC3(type, name1, name2, name3, size) \
vector<type> name1(size), name2(size), name3(size); \
for(int i = 0; i < size; i++) IN(name1[i], name2[i], name3[i])
#define VEC3d(type, name1, name2, name3, size) \
vector<type> name1(size), name2(size), name3(size); \
for(int i = 0; i < size; i++) IN2(name1[i], name2[i], name3[i])
#define VEC4(type, name1, name2, name3, name4, size) \
vector<type> name1(size), name2(size), name3(size), name4(size); \
for(int i = 0; i < size; i++) IN(name1[i], name2[i], name3[i], name4[i]);
#define VEC4d(type, name1, name2, name3, name4, size) \
vector<type> name1(size), name2(size), name3(size), name4(size); \
for(int i = 0; i < size; i++) IN2(name1[i], name2[i], name3[i], name4[i]);
#define VV(type, name, h, w) \
vector<vector<type>> name(h, vector<type>(w)); \
IN(name)
#define VVd(type, name, h, w) \
vector<vector<type>> name(h, vector<type>(w)); \
IN2(name)
int scan() { return getchar(); }
void scan(int &a) { cin >> a; }
void scan(long long &a) { cin >> a; }
void scan(char &a) { cin >> a; }
void scan(double &a) { cin >> a; }
void scan(string &a) { cin >> a; }
template <class T, class S> void scan(pair<T, S> &p) { scan(p.first), scan(p.second); }
template <class T> void scan(vector<T> &);
template <class T> void scan(vector<T> &a) {
for(auto &i : a) scan(i);
}
template <class T> void scan(T &a) { cin >> a; }
void IN() {}
void IN2() {}
template <class Head, class... Tail> void IN(Head &head, Tail &...tail) {
scan(head);
IN(tail...);
}
template <class Head, class... Tail> void IN2(Head &head, Tail &...tail) {
scan(head);
--head;
IN2(tail...);
}
template <int p = -1> void pat() {}
template <int p = -1, class Head, class... Tail> void pat(Head &h, Tail &...tail) {
h += p;
pat<p>(tail...);
}
template <typename T, typename S> T ceil(T x, S y) {
assert(y);
return (y < 0 ? ceil(-x, -y) : (x > 0 ? (x + y - 1) / y : x / y));
}
template <typename T, typename S> T floor(T x, S y) {
assert(y);
return (y < 0 ? floor(-x, -y) : (x > 0 ? x / y : x / y - (x % y == 0 ? 0 : 1)));
}
template <typename T, typename S, typename U> U bigmul(const T &x, const S &y, const U &lim) { // clamp(x * y, -lim, lim)
if(x < 0 and y < 0) return bigmul(-x, -y, lim);
if(x < 0) return -bigmul(-x, y, lim);
if(y < 0) return -bigmul(x, -y, lim);
return y == 0 or x <= lim / y ? x * y : lim;
}
template <class T> T POW(T x, int n) {
T res = 1;
for(; n; n >>= 1, x *= x)
if(n & 1) res *= x;
return res;
}
template <class T, class S> T POW(T x, S n, const ll &mod) {
T res = 1;
x %= mod;
for(; n; n >>= 1, x = x * x % mod)
if(n & 1) res = res * x % mod;
return res;
}
vector<pll> factor(ll x) {
vector<pll> ans;
for(ll i = 2; i * i <= x; i++)
if(x % i == 0) {
ans.push_back({i, 1});
while((x /= i) % i == 0) ans.back().second++;
}
if(x != 1) ans.push_back({x, 1});
return ans;
}
template <class T> vector<T> divisor(T x) {
vector<T> ans;
for(T i = 1; i * i <= x; i++)
if(x % i == 0) {
ans.pb(i);
if(i * i != x) ans.pb(x / i);
}
return ans;
}
template <typename T> void zip(vector<T> &x) {
vector<T> y = x;
UNIQUE(y);
for(int i = 0; i < x.size(); ++i) { x[i] = lb(y, x[i]); }
}
template <class S> void fold_in(vector<S> &v) {}
template <typename Head, typename... Tail, class S> void fold_in(vector<S> &v, Head &&a, Tail &&...tail) {
for(auto e : a) v.emplace_back(e);
fold_in(v, tail...);
}
template <class S> void renumber(vector<S> &v) {}
template <typename Head, typename... Tail, class S> void renumber(vector<S> &v, Head &&a, Tail &&...tail) {
for(auto &&e : a) e = lb(v, e);
renumber(v, tail...);
}
template <class S, class... Args> vector<S> zip(vector<S> &head, Args &&...args) {
vector<S> v;
fold_in(v, head, args...);
sort(all(v)), v.erase(unique(all(v)), v.end());
renumber(v, head, args...);
return v;
}
template <typename S> void rearrange(const vector<S> &id) {}
template <typename S, typename T> void rearrange_exec(const vector<S> &id, vector<T> &v) {
vector<T> w(v.size());
rep(i, si(id)) w[i] = v[id[i]];
v.swap(w);
}
// 並び替える順番, 並び替える vector 達
template <typename S, typename Head, typename... Tail> void rearrange(const vector<S> &id, Head &a, Tail &...tail) {
rearrange_exec(id, a);
rearrange(id, tail...);
}
template <typename T> vector<T> RUI(const vector<T> &v) {
vector<T> res(v.size() + 1);
for(int i = 0; i < v.size(); i++) res[i + 1] = res[i] + v[i];
return res;
}
template <typename T> void zeta_supersetsum(vector<T> &f) {
int n = f.size();
for(int i = 1; i < n; i <<= 1) rep(b, n) if(!(i & b)) f[b] += f[b | i];
}
template <typename T> void zeta_subsetsum(vector<T> &f) {
int n = f.size();
for(int i = 1; i < n; i <<= 1) rep(b, n) if(!(i & b)) f[b | i] += f[b];
}
template <typename T> void mobius_subset(vector<T> &f) {
int n = f.size();
for(int i = 1; i < n; i <<= 1) rep(b, n) if(!(i & b)) f[b] -= f[b | i];
}
template <typename T> void mobius_superset(vector<T> &f) {
int n = f.size();
for(int i = 1; i < n; i <<= 1) rep(b, n) if(!(i & b)) f[b | i] -= f[b];
}
// 反時計周りに 90 度回転
template <typename T> void rot(vector<vector<T>> &v) {
if(empty(v)) return;
int n = v.size(), m = v[0].size();
vector<vector<T>> res(m, vector<T>(n));
rep(i, n) rep(j, m) res[m - 1 - j][i] = v[i][j];
v.swap(res);
}
vector<int> counter(const vector<int> &v, int max_num = -1) {
if(max_num == -1) max_num = MAX(v);
vector<int> res(max_num + 1);
fore(e, v) res[e]++;
return res;
}
// x in [l, r)
template <class T, class S> bool inc(const T &x, const S &l, const S &r) { return l <= x and x < r; }
template <class T, class S> bool inc(const T &x, const pair<S, S> &p) { return p.first <= x and x < p.second; }
// 便利関数
constexpr ll ten(int n) { return n == 0 ? 1 : ten(n - 1) * 10; }
constexpr ll tri(ll n) { return n * (n + 1) / 2; }
// l + ... + r
constexpr ll tri(ll l, ll r) { return (l + r) * (r - l + 1) / 2; }
ll max(int x, ll y) { return max((ll)x, y); }
ll max(ll x, int y) { return max(x, (ll)y); }
int min(int x, ll y) { return min((ll)x, y); }
int min(ll x, int y) { return min(x, (ll)y); }
// bit 演算系
#define bit(i) (1LL << i) // (1 << i)
#define test(b, i) (b >> i & 1) // b の i bit 目が立っているか
ll pow2(int i) { return 1LL << i; }
int topbit(signed t) { return t == 0 ? -1 : 31 - __builtin_clz(t); }
int topbit(ll t) { return t == 0 ? -1 : 63 - __builtin_clzll(t); }
int lowbit(signed a) { return a == 0 ? 32 : __builtin_ctz(a); }
int lowbit(ll a) { return a == 0 ? 64 : __builtin_ctzll(a); }
// int allbit(int n) { return (1 << n) - 1; }
constexpr ll mask(int n) { return (1LL << n) - 1; }
// int popcount(signed t) { return __builtin_popcount(t); }
// int popcount(ll t) { return __builtin_popcountll(t); }
int popcount(uint64_t t) { return __builtin_popcountll(t); }
static inline uint64_t popcount64(uint64_t x) {
uint64_t m1 = 0x5555555555555555ll;
uint64_t m2 = 0x3333333333333333ll;
uint64_t m4 = 0x0F0F0F0F0F0F0F0Fll;
uint64_t h01 = 0x0101010101010101ll;
x -= (x >> 1) & m1;
x = (x & m2) + ((x >> 2) & m2);
x = (x + (x >> 4)) & m4;
return (x * h01) >> 56;
}
bool ispow2(int i) { return i && (i & -i) == i; }
ll rnd(ll l, ll r) { //[l, r)
#ifdef noimi
static mt19937_64 gen;
#else
static mt19937_64 gen(chrono::steady_clock::now().time_since_epoch().count());
#endif
return uniform_int_distribution<ll>(l, r - 1)(gen);
}
ll rnd(ll n) { return rnd(0, n); }
template <class t> void random_shuffle(vc<t> &a) { rep(i, si(a)) swap(a[i], a[rnd(0, i + 1)]); }
int in() {
int x;
cin >> x;
return x;
}
ll lin() {
unsigned long long x;
cin >> x;
return x;
}
template <class T, class S> pair<T, S> operator-(const pair<T, S> &x) { return pair<T, S>(-x.first, -x.second); }
template <class T, class S> pair<T, S> operator-(const pair<T, S> &x, const pair<T, S> &y) { return pair<T, S>(x.fi - y.fi, x.se - y.se); }
template <class T, class S> pair<T, S> operator+(const pair<T, S> &x, const pair<T, S> &y) { return pair<T, S>(x.fi + y.fi, x.se + y.se); }
template <class T> pair<T, T> operator&(const pair<T, T> &l, const pair<T, T> &r) { return pair<T, T>(max(l.fi, r.fi), min(l.se, r.se)); }
template <class T, class S> pair<T, S> operator+=(pair<T, S> &l, const pair<T, S> &r) { return l = l + r; }
template <class T, class S> pair<T, S> operator-=(pair<T, S> &l, const pair<T, S> &r) { return l = l - r; }
template <class T> bool intersect(const pair<T, T> &l, const pair<T, T> &r) { return (l.se < r.se ? r.fi < l.se : l.fi < r.se); }
template <class T> vector<T> &operator++(vector<T> &v) {
fore(e, v) e++;
return v;
}
template <class T> vector<T> operator++(vector<T> &v, int) {
auto res = v;
fore(e, v) e++;
return res;
}
template <class T> vector<T> &operator--(vector<T> &v) {
fore(e, v) e--;
return v;
}
template <class T> vector<T> operator--(vector<T> &v, int) {
auto res = v;
fore(e, v) e--;
return res;
}
template <class T> void connect(vector<T> &l, const vector<T> &r) { fore(e, r) l.eb(e); }
template <class T> vector<T> operator+(const vector<T> &l, const vector<T> &r) {
vector<T> res(max(si(l), si(r)));
rep(i, si(l)) res[i] += l[i];
rep(i, si(r)) res[i] += r[i];
return res;
}
template <class T> vector<T> operator-(const vector<T> &l, const vector<T> &r) {
vector<T> res(max(si(l), si(r)));
rep(i, si(l)) res[i] += l[i];
rep(i, si(r)) res[i] -= r[i];
return res;
}
template <class T> vector<T> &operator+=(const vector<T> &l, const vector<T> &r) {
if(si(l) < si(r)) l.resize(si(r));
rep(i, si(r)) l[i] += r[i];
return l;
}
template <class T> vector<T> &operator-=(const vector<T> &l, const vector<T> &r) {
if(si(l) < si(r)) l.resize(si(r));
rep(i, si(r)) l[i] -= r[i];
return l;
}
template <class T> vector<T> &operator+=(vector<T> &v, const T &x) {
fore(e, v) e += x;
return v;
}
template <class T> vector<T> &operator-=(vector<T> &v, const T &x) {
fore(e, v) e -= x;
return v;
}
template <typename T> struct edge {
int from, to;
T cost;
int id;
edge(int to, T cost) : from(-1), to(to), cost(cost) {}
edge(int from, int to, T cost) : from(from), to(to), cost(cost) {}
edge(int from, int to, T cost, int id) : from(from), to(to), cost(cost), id(id) {}
constexpr bool operator<(const edge<T> &rhs) const noexcept { return cost < rhs.cost; }
edge &operator=(const int &x) {
to = x;
return *this;
}
operator int() const { return to; }
friend ostream operator<<(ostream &os, const edge &e) { return os << e.to; }
};
template <typename T> using Edges = vector<edge<T>>;
template <typename T = int> Edges<T> read_edges(int m, bool weighted = false) {
Edges<T> res;
res.reserve(m);
for(int i = 0; i < m; i++) {
int u, v, c = 0;
scan(u), scan(v), u--, v--;
if(weighted) scan(c);
res.eb(u, v, c, i);
}
return res;
}
using Tree = vector<vector<int>>;
using Graph = vector<vector<int>>;
template <class T> using Wgraph = vector<vector<edge<T>>>;
Graph getG(int n, int m = -1, bool directed = false, int margin = 1) {
Tree res(n);
if(m == -1) m = n - 1;
while(m--) {
int a, b;
cin >> a >> b;
a -= margin, b -= margin;
res[a].emplace_back(b);
if(!directed) res[b].emplace_back(a);
}
return res;
}
Graph getTreeFromPar(int n, int margin = 1) {
Graph res(n);
for(int i = 1; i < n; i++) {
int a;
cin >> a;
res[a - margin].emplace_back(i);
}
return res;
}
template <class T> Wgraph<T> getWg(int n, int m = -1, bool directed = false, int margin = 1) {
Wgraph<T> res(n);
if(m == -1) m = n - 1;
while(m--) {
int a, b;
T c;
scan(a), scan(b), scan(c);
a -= margin, b -= margin;
res[a].emplace_back(b, c);
if(!directed) res[b].emplace_back(a, c);
}
return res;
}
void add(Graph &G, int x, int y) { G[x].eb(y), G[y].eb(x); }
template <class S, class T> void add(Wgraph<S> &G, int x, int y, T c) { G[x].eb(y, c), G[y].eb(x, c); }
#define TEST \
INT(testcases); \
while(testcases--)
i128 abs(const i128 &x) { return x > 0 ? x : -x; }
istream &operator>>(istream &is, i128 &v) {
string s;
is >> s;
v = 0;
for(int i = 0; i < (int)s.size(); i++) {
if(isdigit(s[i])) { v = v * 10 + s[i] - '0'; }
}
if(s[0] == '-') { v *= -1; }
return is;
}
ostream &operator<<(ostream &os, const i128 &v) {
if(v == 0) { return (os << "0"); }
i128 num = v;
if(v < 0) {
os << '-';
num = -num;
}
string s;
for(; num > 0; num /= 10) { s.push_back((char)(num % 10) + '0'); }
reverse(s.begin(), s.end());
return (os << s);
}
namespace aux {
template <typename T, unsigned N, unsigned L> struct tp {
static void output(std::ostream &os, const T &v) {
os << std::get<N>(v) << (&os == &cerr ? ", " : " ");
tp<T, N + 1, L>::output(os, v);
}
};
template <typename T, unsigned N> struct tp<T, N, N> {
static void output(std::ostream &os, const T &v) { os << std::get<N>(v); }
};
} // namespace aux
template <typename... Ts> std::ostream &operator<<(std::ostream &os, const std::tuple<Ts...> &t) {
if(&os == &cerr) { os << '('; }
aux::tp<std::tuple<Ts...>, 0, sizeof...(Ts) - 1>::output(os, t);
if(&os == &cerr) { os << ')'; }
return os;
}
template <typename T, typename S, typename U> std::ostream &operator<<(std::ostream &os, const priority_queue<T, S, U> &_pq) {
auto pq = _pq;
vector<T> res;
while(!empty(pq)) res.emplace_back(pq.top()), pq.pop();
return os << res;
}
template <class T, class S> ostream &operator<<(ostream &os, const pair<T, S> &p) {
if(&os == &cerr) { return os << "(" << p.first << ", " << p.second << ")"; }
return os << p.first << " " << p.second;
}
template <class Ch, class Tr, class Container> std::basic_ostream<Ch, Tr> &operator<<(std::basic_ostream<Ch, Tr> &os, const Container &x) {
bool f = true;
if(&os == &cerr) os << "[";
for(auto &y : x) {
if(&os == &cerr)
os << (f ? "" : ", ") << y;
else
os << (f ? "" : " ") << y;
f = false;
}
if(&os == &cerr) os << "]";
return os;
}
#define dump(...) static_cast<void>(0)
#define dbg(...) static_cast<void>(0)
void OUT() { cout << endl; }
template <class Head, class... Tail> void OUT(const Head &head, const Tail &...tail) {
cout << head;
if(sizeof...(tail)) cout << ' ';
OUT(tail...);
}
template <typename T> static constexpr T inf = numeric_limits<T>::max() / 2;
template <class T, class S> constexpr pair<T, S> inf<pair<T, S>> = {inf<T>, inf<S>};
template <class T> void OUT2(const T &t, T INF = inf<T>, T res = -1) { OUT(t != INF ? t : res); }
template <class T> void OUT2(vector<T> &v, T INF = inf<T>, T res = -1) {
fore(e, v) if(e == INF) e = res;
OUT(v);
fore(e, v) if(e == res) e = INF;
}
template <class F> struct REC {
F f;
REC(F &&f_) : f(forward<F>(f_)) {}
template <class... Args> auto operator()(Args &&...args) const { return f(*this, forward<Args>(args)...); }
};
template <class S> vector<pair<S, int>> runLength(const vector<S> &v) {
vector<pair<S, int>> res;
for(auto &e : v) {
if(res.empty() or res.back().fi != e)
res.eb(e, 1);
else
res.back().se++;
}
return res;
}
vector<pair<char, int>> runLength(const string &v) {
vector<pair<char, int>> res;
for(auto &e : v) {
if(res.empty() or res.back().fi != e)
res.eb(e, 1);
else
res.back().se++;
}
return res;
}
struct string_converter {
char start = 0;
char type(const char &c) const { return (islower(c) ? 'a' : isupper(c) ? 'A' : isdigit(c) ? '0' : 0); }
int convert(const char &c) {
if(!start) start = type(c);
return c - start;
}
int convert(const char &c, const string &chars) { return chars.find(c); }
template <typename T> auto convert(const T &v) {
vector<decltype(convert(v[0]))> ret;
ret.reserve(size(v));
for(auto &&e : v) ret.emplace_back(convert(e));
return ret;
}
template <typename T> auto convert(const T &v, const string &chars) {
vector<decltype(convert(v[0], chars))> ret;
ret.reserve(size(v));
for(auto &&e : v) ret.emplace_back(convert(e, chars));
return ret;
}
int operator()(const char &v, char s = 0) {
start = s;
return convert(v);
}
int operator()(const char &v, const string &chars) { return convert(v, chars); }
template <typename T> auto operator()(const T &v, char s = 0) {
start = s;
return convert(v);
}
template <typename T> auto operator()(const T &v, const string &chars) { return convert(v, chars); }
} toint;
template <class T, class F> T bin_search(T ok, T ng, const F &f) {
while((ok > ng ? ok - ng : ng - ok) > 1) {
T mid = ok + ng >> 1;
(f(mid) ? ok : ng) = mid;
}
return ok;
}
template <class T, class F> T bin_search_double(T ok, T ng, const F &f, int iter = 80) {
while(iter--) {
// T mid = (ok + ng) / 2;
T mid = sqrtl(ok * ng);
(f(mid) ? ok : ng) = mid;
}
return ok;
}
struct Setup_io {
Setup_io() {
ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);
cout << fixed << setprecision(11);
}
} setup_io;
#endif
#pragma endregion
struct UnionFind {
vector<int> data;
int num;
UnionFind(int n) : num(n) { data.assign(n, -1); }
bool unite(int x, int y) {
x = find(x), y = find(y);
if(x == y) return false;
num--;
if(data[x] > data[y]) swap(x, y);
data[x] += data[y];
data[y] = x;
return true;
}
bool same(int x, int y) { return find(x) == find(y); }
int find(int x) {
if(data[x] < 0) return x;
return (data[x] = find(data[x]));
}
int size(int x) { return -data[find(x)]; }
const int operator[](const int k) { return find(k); }
vector<vector<int>> belong() {
vector<vector<int>> res(data.size());
for(int i = 0; i < data.size(); i++) res[find(i)].emplace_back(i);
return res;
}
void reset() {
num = data.size();
data.assign(num, -1);
}
};
struct Grid {
const int n, m;
Grid(int n, int m) : n(n), m(m) {}
struct GridSquare {
const int &n, &m;
int x, y;
GridSquare(const int &n, const int &m, int x, int y) : x(x), y(y), n(n), m(m) {}
struct itr {
const int &n, &m, &x, &y;
inline constexpr bool inc_x(int x) const { return 0 <= x and x < n; }
inline constexpr bool inc_y(int y) const { return 0 <= y and y < m; }
int i;
itr(const int &n, const int &m, const int &x, const int &y) : n(n), m(m), x(x), y(y), i(0) {
while(i < 4 and (!inc_x(dx4[i].fi + x) or !inc_y(dx4[i].se + y))) { i++; }
}
bool operator!=(const itr &) const { return i != 4; }
void operator++() {
while(i != 4) {
i++;
if(inc(dx4[i].fi + x, 0, n) and inc(dx4[i].se + y, 0, m)) break;
}
}
pair<int, int> operator*() const { return pair(x + dx4[i].fi, y + dx4[i].se); }
};
itr begin() const { return itr(n, m, x, y); }
itr end() const { return itr(n, m, x, y); }
};
GridSquare get(int x, int y) { return GridSquare(n, m, x, y); }
int id(int x, int y) { return x * m + y; }
};
int main() {
INT(n);
if(n == 1) {
YES();
OUT(1);
exit(0);
}
if(n == 3) {
YES();
OUT(1, 3, 2);
exit(0);
}
vi v{4, 6, 2, 3, 1, 5, 7};
if(n == 7) {
YES();
OUT(v);
exit(0);
}
if(n < 7) drop(NO);
int t = topbit(n);
if(n <= (1 << t) + (1 << t - 1)) drop(NO);
vvc<int> w(20);
w[2] = vi{1, 3, 2};
w[3] = v;
int idx = 4;
auto gray = [&](int m) {
vi v;
rep(i, 1, 1 << m) v.eb(i ^ (i >> 1));
return v;
};
while(si(v) < n) {
vi nxt;
nxt.eb((1 << idx - 1) + (1 << idx - 2));
fore(e, w[idx - 1]) nxt.eb(e);
nxt.eb((1 << idx - 1) + (1 << idx - 2) + 1);
fore(e, gray(idx - 2)) nxt.eb(e + (1 << idx - 1));
nxt.eb((1 << idx - 1));
dump(nxt);
vi nnxt;
fore(e, nxt) {
nnxt.eb(e);
int ne = e + bit(idx - 1);
if(!test(e, idx - 1) and ne > (bit(idx - 1) + bit(idx - 2) + 1) and ne <= n) nnxt.eb(ne);
}
swap(v, nnxt);
int ma = mask(idx);
auto it = find(all(v), ma);
if(it != end(v)) v.erase(it), v.eb(ma);
w[idx] = v;
idx++;
dump(v);
}
YES();
OUT(v);
{
auto tv = v;
tv.eb(0);
SORT(tv);
assert(tv == iota(n + 1));
}
// int m = topbit(n) + 1;
// vv(int, a, n, m);
// rep(i, n) { rep(j, m) a[i][j] = test(v[i], j); }
// UnionFind uf(n * m);
// Grid g(n, m);
// rep(i, n) rep(j, m) fore(ni, nj, g.get(i, j)) if(a[i][j] and a[ni][nj]) uf.unite(i * m + j, ni * m + nj);
// fore(e, v) {
// per(i, m) cout << test(e, i);
// OUT();
// }
// bool flag = true;
// assert(a[0][0]);
// rep
// assert(ma == n);
}
这程序好像有点Bug,我给组数据试试?
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3584kb
input:
1
output:
YES 1
result:
ok answer is 1
Test #2:
score: 0
Accepted
time: 0ms
memory: 3788kb
input:
2
output:
NO
result:
ok answer is 0
Test #3:
score: 0
Accepted
time: 0ms
memory: 3868kb
input:
3
output:
YES 1 3 2
result:
ok answer is 1
Test #4:
score: 0
Accepted
time: 0ms
memory: 3864kb
input:
4
output:
NO
result:
ok answer is 0
Test #5:
score: 0
Accepted
time: 0ms
memory: 3528kb
input:
5
output:
NO
result:
ok answer is 0
Test #6:
score: 0
Accepted
time: 0ms
memory: 3588kb
input:
6
output:
NO
result:
ok answer is 0
Test #7:
score: 0
Accepted
time: 0ms
memory: 3580kb
input:
7
output:
YES 4 6 2 3 1 5 7
result:
ok answer is 1
Test #8:
score: 0
Accepted
time: 0ms
memory: 3604kb
input:
8
output:
NO
result:
ok answer is 0
Test #9:
score: 0
Accepted
time: 0ms
memory: 3536kb
input:
9
output:
NO
result:
ok answer is 0
Test #10:
score: 0
Accepted
time: 0ms
memory: 3792kb
input:
10
output:
NO
result:
ok answer is 0
Test #11:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
11
output:
NO
result:
ok answer is 0
Test #12:
score: 0
Accepted
time: 0ms
memory: 3852kb
input:
12
output:
NO
result:
ok answer is 0
Test #13:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
13
output:
YES 12 4 6 2 3 1 5 7 13 9 11 10 8
result:
ok answer is 1
Test #14:
score: 0
Accepted
time: 0ms
memory: 3568kb
input:
14
output:
YES 12 4 6 14 2 3 1 5 7 13 9 11 10 8
result:
ok answer is 1
Test #15:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
15
output:
YES 12 4 6 14 2 3 1 5 7 13 9 11 10 8 15
result:
ok answer is 1
Test #16:
score: 0
Accepted
time: 0ms
memory: 3516kb
input:
16
output:
NO
result:
ok answer is 0
Test #17:
score: 0
Accepted
time: 0ms
memory: 3632kb
input:
17
output:
NO
result:
ok answer is 0
Test #18:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
23
output:
NO
result:
ok answer is 0
Test #19:
score: 0
Accepted
time: 0ms
memory: 3808kb
input:
24
output:
NO
result:
ok answer is 0
Test #20:
score: 0
Accepted
time: 0ms
memory: 3664kb
input:
25
output:
YES 24 12 4 6 14 2 3 1 5 7 13 9 11 10 8 15 25 17 19 18 22 23 21 20 16
result:
ok answer is 1
Test #21:
score: 0
Accepted
time: 0ms
memory: 3576kb
input:
26
output:
YES 24 12 4 6 14 2 3 1 5 7 13 9 11 10 26 8 15 25 17 19 18 22 23 21 20 16
result:
ok answer is 1
Test #22:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
27
output:
YES 24 12 4 6 14 2 3 1 5 7 13 9 11 27 10 26 8 15 25 17 19 18 22 23 21 20 16
result:
ok answer is 1
Test #23:
score: 0
Accepted
time: 0ms
memory: 3792kb
input:
40
output:
NO
result:
ok answer is 0
Test #24:
score: 0
Accepted
time: 0ms
memory: 3572kb
input:
53
output:
YES 48 24 12 28 4 6 14 30 2 3 1 5 7 13 29 9 11 27 10 26 8 15 25 17 19 51 18 50 22 23 21 53 20 52 16 31 49 33 35 34 38 39 37 36 44 45 47 46 42 43 41 40 32
result:
ok answer is 1
Test #25:
score: 0
Accepted
time: 0ms
memory: 3808kb
input:
93
output:
NO
result:
ok answer is 0
Test #26:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
105
output:
YES 96 48 24 56 12 28 60 4 6 14 30 62 2 3 1 5 7 13 29 61 9 11 27 59 10 26 58 8 15 25 57 17 19 51 18 50 22 54 23 55 21 53 20 52 16 31 49 33 35 99 34 98 38 102 39 103 37 101 36 100 44 45 47 46 42 43 41 105 40 104 32 63 97 65 67 66 70 71 69 68 76 77 79 78 74 75 73 72 88 89 91 90 94 95 93 92 84 85 87 86...
result:
ok answer is 1
Test #27:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
132
output:
NO
result:
ok answer is 0
Test #28:
score: 0
Accepted
time: 0ms
memory: 3536kb
input:
221
output:
YES 192 96 48 112 24 56 120 12 28 60 124 4 6 14 30 62 126 2 3 1 5 7 13 29 61 125 9 11 27 59 123 10 26 58 122 8 15 25 57 121 17 19 51 115 18 50 114 22 54 118 23 55 119 21 53 117 20 52 116 16 31 49 113 33 35 99 34 98 38 102 39 103 37 101 36 100 44 108 45 109 47 111 46 110 42 106 43 107 41 105 40 104 3...
result:
ok answer is 1
Test #29:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
373
output:
NO
result:
ok answer is 0
Test #30:
score: 0
Accepted
time: 0ms
memory: 3808kb
input:
473
output:
YES 384 192 448 96 224 48 112 240 24 56 120 248 12 28 60 124 252 4 6 14 30 62 126 254 2 3 1 5 7 13 29 61 125 253 9 11 27 59 123 251 10 26 58 122 250 8 15 25 57 121 249 17 19 51 115 243 18 50 114 242 22 54 118 246 23 55 119 247 21 53 117 245 20 52 116 244 16 31 49 113 241 33 35 99 227 34 98 226 38 10...
result:
ok answer is 1
Test #31:
score: 0
Accepted
time: 0ms
memory: 3676kb
input:
513
output:
NO
result:
ok answer is 0
Test #32:
score: 0
Accepted
time: 0ms
memory: 3608kb
input:
934
output:
YES 768 384 896 192 448 96 224 480 48 112 240 496 24 56 120 248 504 12 28 60 124 252 508 4 6 14 30 62 126 254 510 2 3 1 5 7 13 29 61 125 253 509 9 11 27 59 123 251 507 10 26 58 122 250 506 8 15 25 57 121 249 505 17 19 51 115 243 499 18 50 114 242 498 22 54 118 246 502 23 55 119 247 503 21 53 117 245...
result:
ok answer is 1
Test #33:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
1356
output:
NO
result:
ok answer is 0
Test #34:
score: 0
Accepted
time: 1ms
memory: 3644kb
input:
1651
output:
YES 1536 768 384 896 192 448 960 96 224 480 992 48 112 240 496 1008 24 56 120 248 504 1016 12 28 60 124 252 508 1020 4 6 14 30 62 126 254 510 1022 2 3 1 5 7 13 29 61 125 253 509 1021 9 11 27 59 123 251 507 1019 10 26 58 122 250 506 1018 8 15 25 57 121 249 505 1017 17 19 51 115 243 499 1011 18 50 114...
result:
ok answer is 1
Test #35:
score: 0
Accepted
time: 0ms
memory: 3588kb
input:
2263
output:
NO
result:
ok answer is 0
Test #36:
score: 0
Accepted
time: 1ms
memory: 3900kb
input:
3330
output:
YES 3072 1536 768 1792 384 896 1920 192 448 960 1984 96 224 480 992 2016 48 112 240 496 1008 2032 24 56 120 248 504 1016 2040 12 28 60 124 252 508 1020 2044 4 6 14 30 62 126 254 510 1022 2046 2 3 1 5 7 13 29 61 125 253 509 1021 2045 9 11 27 59 123 251 507 1019 2043 10 26 58 122 250 506 1018 2042 8 1...
result:
ok answer is 1
Test #37:
score: 0
Accepted
time: 0ms
memory: 3604kb
input:
4375
output:
NO
result:
ok answer is 0
Test #38:
score: 0
Accepted
time: 1ms
memory: 3960kb
input:
7989
output:
YES 6144 3072 7168 1536 3584 7680 768 1792 3840 7936 384 896 1920 3968 192 448 960 1984 4032 96 224 480 992 2016 4064 48 112 240 496 1008 2032 4080 24 56 120 248 504 1016 2040 4088 12 28 60 124 252 508 1020 2044 4092 4 6 14 30 62 126 254 510 1022 2046 4094 2 3 1 5 7 13 29 61 125 253 509 1021 2045 40...
result:
ok answer is 1
Test #39:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
10925
output:
NO
result:
ok answer is 0
Test #40:
score: 0
Accepted
time: 2ms
memory: 3948kb
input:
14097
output:
YES 12288 6144 3072 7168 1536 3584 7680 768 1792 3840 7936 384 896 1920 3968 8064 192 448 960 1984 4032 8128 96 224 480 992 2016 4064 8160 48 112 240 496 1008 2032 4080 8176 24 56 120 248 504 1016 2040 4088 8184 12 28 60 124 252 508 1020 2044 4092 8188 4 6 14 30 62 126 254 510 1022 2046 4094 8190 2 ...
result:
ok answer is 1
Test #41:
score: 0
Accepted
time: 0ms
memory: 3580kb
input:
16893
output:
NO
result:
ok answer is 0
Test #42:
score: 0
Accepted
time: 3ms
memory: 4032kb
input:
28913
output:
YES 24576 12288 28672 6144 14336 3072 7168 15360 1536 3584 7680 15872 768 1792 3840 7936 16128 384 896 1920 3968 8064 16256 192 448 960 1984 4032 8128 16320 96 224 480 992 2016 4064 8160 16352 48 112 240 496 1008 2032 4080 8176 16368 24 56 120 248 504 1016 2040 4088 8184 16376 12 28 60 124 252 508 1...
result:
ok answer is 1
Test #43:
score: 0
Accepted
time: 0ms
memory: 3668kb
input:
40092
output:
NO
result:
ok answer is 0
Test #44:
score: 0
Accepted
time: 5ms
memory: 4936kb
input:
54980
output:
YES 49152 24576 12288 28672 6144 14336 30720 3072 7168 15360 31744 1536 3584 7680 15872 32256 768 1792 3840 7936 16128 32512 384 896 1920 3968 8064 16256 32640 192 448 960 1984 4032 8128 16320 32704 96 224 480 992 2016 4064 8160 16352 32736 48 112 240 496 1008 2032 4080 8176 16368 32752 24 56 120 24...
result:
ok answer is 1
Test #45:
score: 0
Accepted
time: 0ms
memory: 3632kb
input:
88104
output:
NO
result:
ok answer is 0
Test #46:
score: 0
Accepted
time: 7ms
memory: 5960kb
input:
106284
output:
YES 98304 49152 24576 57344 12288 28672 61440 6144 14336 30720 63488 3072 7168 15360 31744 64512 1536 3584 7680 15872 32256 65024 768 1792 3840 7936 16128 32512 65280 384 896 1920 3968 8064 16256 32640 65408 192 448 960 1984 4032 8128 16320 32704 65472 96 224 480 992 2016 4064 8160 16352 32736 65504...
result:
ok answer is 1
Test #47:
score: 0
Accepted
time: 0ms
memory: 3808kb
input:
152797
output:
NO
result:
ok answer is 0
Test #48:
score: 0
Accepted
time: 11ms
memory: 8424kb
input:
200000
output:
YES 196608 98304 49152 114688 24576 57344 122880 12288 28672 61440 126976 6144 14336 30720 63488 129024 3072 7168 15360 31744 64512 130048 1536 3584 7680 15872 32256 65024 130560 768 1792 3840 7936 16128 32512 65280 130816 384 896 1920 3968 8064 16256 32640 65408 130944 192 448 960 1984 4032 8128 16...
result:
ok answer is 1
Test #49:
score: 0
Accepted
time: 1ms
memory: 3744kb
input:
3073
output:
YES 3072 1536 768 1792 384 896 1920 192 448 960 1984 96 224 480 992 2016 48 112 240 496 1008 2032 24 56 120 248 504 1016 2040 12 28 60 124 252 508 1020 2044 4 6 14 30 62 126 254 510 1022 2046 2 3 1 5 7 13 29 61 125 253 509 1021 2045 9 11 27 59 123 251 507 1019 2043 10 26 58 122 250 506 1018 2042 8 1...
result:
ok answer is 1
Test #50:
score: 0
Accepted
time: 2ms
memory: 3692kb
input:
16383
output:
YES 12288 6144 14336 3072 7168 15360 1536 3584 7680 15872 768 1792 3840 7936 16128 384 896 1920 3968 8064 16256 192 448 960 1984 4032 8128 16320 96 224 480 992 2016 4064 8160 16352 48 112 240 496 1008 2032 4080 8176 16368 24 56 120 248 504 1016 2040 4088 8184 16376 12 28 60 124 252 508 1020 2044 409...
result:
ok answer is 1
Test #51:
score: 0
Accepted
time: 3ms
memory: 4296kb
input:
32767
output:
YES 24576 12288 28672 6144 14336 30720 3072 7168 15360 31744 1536 3584 7680 15872 32256 768 1792 3840 7936 16128 32512 384 896 1920 3968 8064 16256 32640 192 448 960 1984 4032 8128 16320 32704 96 224 480 992 2016 4064 8160 16352 32736 48 112 240 496 1008 2032 4080 8176 16368 32752 24 56 120 248 504 ...
result:
ok answer is 1
Test #52:
score: 0
Accepted
time: 0ms
memory: 3668kb
input:
399
output:
YES 384 192 96 224 48 112 240 24 56 120 248 12 28 60 124 252 4 6 14 30 62 126 254 2 3 1 5 7 13 29 61 125 253 9 11 27 59 123 251 10 26 58 122 250 8 15 25 57 121 249 17 19 51 115 243 18 50 114 242 22 54 118 246 23 55 119 247 21 53 117 245 20 52 116 244 16 31 49 113 241 33 35 99 227 34 98 226 38 102 23...
result:
ok answer is 1
Test #53:
score: 0
Accepted
time: 0ms
memory: 3580kb
input:
5757
output:
NO
result:
ok answer is 0
Test #54:
score: 0
Accepted
time: 0ms
memory: 3668kb
input:
179
output:
NO
result:
ok answer is 0
Test #55:
score: 0
Accepted
time: 0ms
memory: 3660kb
input:
228
output:
YES 192 96 224 48 112 24 56 120 12 28 60 124 4 6 14 30 62 126 2 3 1 5 7 13 29 61 125 9 11 27 59 123 10 26 58 122 8 15 25 57 121 17 19 51 115 18 50 114 22 54 118 23 55 119 21 53 117 20 52 116 16 31 49 113 33 35 99 227 34 98 226 38 102 39 103 37 101 36 100 228 44 108 45 109 47 111 46 110 42 106 43 107...
result:
ok answer is 1
Extra Test:
score: 0
Extra Test Passed