結果
問題 | No.1270 Range Arrange Query |
ユーザー |
|
提出日時 | 2020-10-23 22:28:37 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 1,687 ms / 7,000 ms |
コード長 | 11,073 bytes |
コンパイル時間 | 2,779 ms |
コンパイル使用メモリ | 209,840 KB |
最終ジャッジ日時 | 2025-01-15 13:26:05 |
ジャッジサーバーID (参考情報) |
judge1 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 15 |
ソースコード
/*** date : 2020-10-23 22:28:32*/#include <bits/stdc++.h>using namespace std;#pragma region kyopro_template#define Nyaan_template#define pb push_back#define eb emplace_back#define fi first#define se second#define each(x, v) for (auto &x : v)#define all(v) (v).begin(), (v).end()#define sz(v) ((int)(v).size())#define mem(a, val) memset(a, val, sizeof(a))#define ini(...) \int __VA_ARGS__; \in(__VA_ARGS__)#define inl(...) \long long __VA_ARGS__; \in(__VA_ARGS__)#define ins(...) \string __VA_ARGS__; \in(__VA_ARGS__)#define inc(...) \char __VA_ARGS__; \in(__VA_ARGS__)#define in2(s, t) \for (int i = 0; i < (int)s.size(); i++) { \in(s[i], t[i]); \}#define in3(s, t, u) \for (int i = 0; i < (int)s.size(); i++) { \in(s[i], t[i], u[i]); \}#define in4(s, t, u, v) \for (int i = 0; i < (int)s.size(); i++) { \in(s[i], t[i], u[i], v[i]); \}#define rep(i, N) for (long long i = 0; i < (long long)(N); i++)#define repr(i, N) for (long long i = (long long)(N)-1; i >= 0; i--)#define rep1(i, N) for (long long i = 1; i <= (long long)(N); i++)#define repr1(i, N) for (long long i = (N); (long long)(i) > 0; i--)#define reg(i, a, b) for (long long i = (a); i < (b); i++)#define die(...) \do { \out(__VA_ARGS__); \return; \} while (0)using namespace std;using ll = long long;template <class T>using V = vector<T>;using vi = vector<int>;using vl = vector<long long>;using vvi = vector<vector<int>>;using vd = V<double>;using vs = V<string>;using vvl = vector<vector<long long>>;using P = pair<long long, long long>;using vp = vector<P>;using pii = pair<int, int>;using vpi = vector<pair<int, int>>;constexpr int inf = 1001001001;constexpr long long infLL = (1LL << 61) - 1;template <typename T, typename U>inline bool amin(T &x, U y) {return (y < x) ? (x = y, true) : false;}template <typename T, typename U>inline bool amax(T &x, U y) {return (x < y) ? (x = y, true) : false;}template <typename T, typename U>ostream &operator<<(ostream &os, const pair<T, U> &p) {os << p.first << " " << p.second;return os;}template <typename T, typename U>istream &operator>>(istream &is, pair<T, U> &p) {is >> p.first >> p.second;return is;}template <typename T>ostream &operator<<(ostream &os, const vector<T> &v) {int s = (int)v.size();for (int i = 0; i < s; i++) os << (i ? " " : "") << v[i];return os;}template <typename T>istream &operator>>(istream &is, vector<T> &v) {for (auto &x : v) is >> x;return is;}void in() {}template <typename T, class... U>void in(T &t, U &... u) {cin >> t;in(u...);}void out() { cout << "\n"; }template <typename T, class... U>void out(const T &t, const U &... u) {cout << t;if (sizeof...(u)) cout << " ";out(u...);}#ifdef NyaanDebug#define trc(...) \do { \cerr << #__VA_ARGS__ << " = "; \dbg_out(__VA_ARGS__); \} while (0)#define trca(v, N) \do { \cerr << #v << " = "; \array_out(v, N); \} while (0)#define trcc(v) \do { \cerr << #v << " = {"; \each(x, v) { cerr << " " << x << ","; } \cerr << "}" << endl; \} while (0)template <typename T>void _cout(const T &c) {cerr << c;}void _cout(const int &c) {if (c == 1001001001)cerr << "inf";else if (c == -1001001001)cerr << "-inf";elsecerr << c;}void _cout(const unsigned int &c) {if (c == 1001001001)cerr << "inf";elsecerr << c;}void _cout(const long long &c) {if (c == 1001001001 || c == (1LL << 61) - 1)cerr << "inf";else if (c == -1001001001 || c == -((1LL << 61) - 1))cerr << "-inf";elsecerr << c;}void _cout(const unsigned long long &c) {if (c == 1001001001 || c == (1LL << 61) - 1)cerr << "inf";elsecerr << c;}template <typename T, typename U>void _cout(const pair<T, U> &p) {cerr << "{ ";_cout(p.fi);cerr << ", ";_cout(p.se);cerr << " } ";}template <typename T>void _cout(const vector<T> &v) {int s = v.size();cerr << "{ ";for (int i = 0; i < s; i++) {cerr << (i ? ", " : "");_cout(v[i]);}cerr << " } ";}template <typename T>void _cout(const vector<vector<T>> &v) {cerr << "[ ";for (const auto &x : v) {cerr << endl;_cout(x);cerr << ", ";}cerr << endl << " ] ";}void dbg_out() { cerr << endl; }template <typename T, class... U>void dbg_out(const T &t, const U &... u) {_cout(t);if (sizeof...(u)) cerr << ", ";dbg_out(u...);}template <typename T>void array_out(const T &v, int s) {cerr << "{ ";for (int i = 0; i < s; i++) {cerr << (i ? ", " : "");_cout(v[i]);}cerr << " } " << endl;}template <typename T>void array_out(const T &v, int H, int W) {cerr << "[ ";for (int i = 0; i < H; i++) {cerr << (i ? ", " : "");array_out(v[i], W);}cerr << " ] " << endl;}#else#define trc(...)#define trca(...)#define trcc(...)#endifinline int popcnt(unsigned long long a) { return __builtin_popcountll(a); }inline int lsb(unsigned long long a) { return __builtin_ctzll(a); }inline int msb(unsigned long long a) { return 63 - __builtin_clzll(a); }template <typename T>inline int getbit(T a, int i) {return (a >> i) & 1;}template <typename T>inline void setbit(T &a, int i) {a |= (1LL << i);}template <typename T>inline void delbit(T &a, int i) {a &= ~(1LL << i);}template <typename T>int lb(const vector<T> &v, const T &a) {return lower_bound(begin(v), end(v), a) - begin(v);}template <typename T>int ub(const vector<T> &v, const T &a) {return upper_bound(begin(v), end(v), a) - begin(v);}template <typename T>int btw(T a, T x, T b) {return a <= x && x < b;}template <typename T, typename U>T ceil(T a, U b) {return (a + b - 1) / b;}constexpr long long TEN(int n) {long long ret = 1, x = 10;while (n) {if (n & 1) ret *= x;x *= x;n >>= 1;}return ret;}template <typename T>vector<T> mkrui(const vector<T> &v) {vector<T> ret(v.size() + 1);for (int i = 0; i < int(v.size()); i++) ret[i + 1] = ret[i] + v[i];return ret;};template <typename T>vector<T> mkuni(const vector<T> &v) {vector<T> ret(v);sort(ret.begin(), ret.end());ret.erase(unique(ret.begin(), ret.end()), ret.end());return ret;}template <typename F>vector<int> mkord(int N, F f) {vector<int> ord(N);iota(begin(ord), end(ord), 0);sort(begin(ord), end(ord), f);return ord;}template <typename T = int>vector<T> mkiota(int N) {vector<T> ret(N);iota(begin(ret), end(ret), 0);return ret;}template <typename T>vector<int> mkinv(vector<T> &v) {vector<int> inv(v.size());for (int i = 0; i < (int)v.size(); i++) inv[v[i]] = i;return inv;}struct IoSetupNya {IoSetupNya() {cin.tie(nullptr);ios::sync_with_stdio(false);cout << fixed << setprecision(15);cerr << fixed << setprecision(7);}} iosetupnya;void solve();int main() { solve(); }#pragma endregionusing namespace std;template <typename T>struct BinaryIndexedTree {int N;vector<T> data;BinaryIndexedTree() = default;BinaryIndexedTree(int size) { init(size); }void init(int size) {N = size + 2;data.assign(N + 1, 0);}// get sum of [0,k]T sum(int k) const {if (k < 0) return 0; // return 0 if k < 0T ret = 0;for (++k; k > 0; k -= k & -k) ret += data[k];return ret;}// getsum of [l,r]inline T sum(int l, int r) const { return sum(r) - sum(l - 1); }// get value of kinline T operator[](int k) const { return sum(k) - sum(k - 1); }// data[k] += xvoid add(int k, T x) {for (++k; k < N; k += k & -k) data[k] += x;}// range add x to [l,r]void imos(int l, int r, T x) {add(l, x);add(r + 1, -x);}// minimize i s.t. sum(i) >= wint lower_bound(T w) {if (w <= 0) return 0;int x = 0;for (int k = 1 << __lg(N); k; k >>= 1) {if (x + k <= N - 1 && data[x + k] < w) {w -= data[x + k];x += k;}}return x;}// minimize i s.t. sum(i) > wint upper_bound(T w) {if (w < 0) return 0;int x = 0;for (int k = 1 << __lg(N); k; k >>= 1) {if (x + k <= N - 1 && data[x + k] <= w) {w -= data[x + k];x += k;}}return x;}};using namespace std;struct Mo {int width;vector<int> left, right, order;int n;Mo(int N, int Q) : order(Q) {n = N;width = max(1, N / max<int>(1, sqrt(Q / 3)));iota(begin(order), end(order), 0);}void insert(int l, int r) { /* [l, r) */left.emplace_back(l);right.emplace_back(r);}template <typename AL, typename AR, typename DL, typename DR, typename REM>void run(const AL &add_left, const AR &add_right, const DL &delete_left,const DR &delete_right, const REM &rem) {assert(left.size() == order.size());sort(begin(order), end(order), [&](int a, int b) {int ablock = left[a] / width, bblock = left[b] / width;if (ablock != bblock) return ablock < bblock;if (ablock & 1) return right[a] < right[b];return right[a] > right[b];});int nl = 0, nr = n;for (auto idx : order) {trc(left[idx],right[idx]);while (nl > left[idx]) delete_left(--nl);while (nl < left[idx]) add_left(nl++);while (nr < right[idx]) delete_right(nr++);while (nr > right[idx]) add_right(--nr);rem(idx);}}};void solve() {ini(N, Q);vi a(N);in(a);Mo mo(N, Q);vi L(Q), R(Q);rep(i, Q) {ini(l, r);--l;mo.insert(l, r);L[i] = l;R[i] = r;}vi lcnt(N + 1);vi rcnt(N + 1);BinaryIndexedTree<int> lbit(N + 1), rbit(N + 1);ll rev = 0;auto ladd = [&](int i) {lcnt[a[i]]++;rev += rbit.sum(1, a[i] - 1) + lbit.sum(a[i] + 1, N);lbit.add(a[i], 1);};auto radd = [&](int i) {rcnt[a[i]]++;rev += rbit.sum(1, a[i] - 1) + lbit.sum(a[i] + 1, N);rbit.add(a[i], 1);};auto ldel = [&](int i) {lcnt[a[i]]--;rev -= rbit.sum(1, a[i] - 1) + lbit.sum(a[i] + 1, N);lbit.add(a[i], -1);};auto rdel = [&](int i) {rcnt[a[i]]--;rev -= rbit.sum(1, a[i] - 1) + lbit.sum(a[i] + 1, N);rbit.add(a[i], -1);};vi ans(Q);auto que = [&](int id) {// ruisekiauto lrui = mkrui(lcnt);auto rrui = mkrui(rcnt);//ll mi = inf;rep1(i, N) {int cur = 0;// hidari [i + 1, N + 1)cur += lrui[N + 1] - lrui[i + 1];// migi [0, i - 1)cur += rrui[i];amin(mi, cur);}ans[id] = rev + mi * (R[id] - L[id]);};mo.run(ladd,radd,ldel,rdel,que);each(x, ans) out(x);}