线段树板题求调教
  • 板块CF240F TorCoder
  • 楼主Infter
  • 当前回复0
  • 已保存回复0
  • 发布时间2024/10/13 13:06
  • 上次更新2024/10/13 15:09:06
查看原帖
线段树板题求调教
386547
Infter楼主2024/10/13 13:06

rt。

WA on Test 7

但好像都没有警钟里的问题。

#include <bits/stdc++.h>
using namespace std;

#define int long long
#define endl '\n'
#define debug(x) cerr << #x << " = " << x << endl
#define rep(i, a, b) for (int i = (a); i <= (b); i++)
#define per(i, a, b) for (int i = (a); i >= (b); i--)
#define gn(u, v) for (int v : G.G[u])
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define sz(x) (int)(x).size()
#define pii pair<int, int>
#define vi vector<int>
#define vpii vector<pii>
#define vvi vector<vi>
#define no cout << "NO" << endl
#define yes cout << "YES" << endl
#define all(x) x.begin(), x.end()
#define rall(x) x.rbegin(), x.rend()
#define tomin(x, y) ((x) = min((x), (y)))
#define tomax(x, y) ((x) = max((x), (y)))
#define ck(mask, i) (((mask) >> (i)) & 1)
#define pq priority_queue

constexpr int MAXN = 1e5 + 5;

int n, m;
string a;

vector<int> operator+(const vector<int>& a, const vector<int>& b) {
    vector<int> res(26, 0);
    rep(i, 0, 25) {
        res[i] = a[i] + b[i];
    }
    return res;
}

struct SegTree {
    struct Node {
        int l, r, lz;
        vector<int> cnt;
    } tr[MAXN * 4];

    void pushup(int k) {
        rep(i, 0, 25) {
            tr[k].cnt[i] = tr[k * 2].cnt[i] + tr[k * 2 + 1].cnt[i];
        }
    }

    void lazy(int k, int v) {
        // assert(!v);
        tr[k].lz = v;
        rep(i, 0, 25) {
            if (v == i) {
                tr[k].cnt[i] = (tr[k].r - tr[k].l + 1);
            } else {
                tr[k].cnt[i] = 0;
            }
        }
    }

    void pushdown(int k) {
        if (!tr[k].lz)
            return;
        lazy(k * 2, tr[k].lz);
        lazy(k * 2 + 1, tr[k].lz);
        tr[k].lz = 0;
    }

    void build(int k, int l, int r) {
        tr[k] = { l, r, 0, vector<int>(26, 0) };
        tr[k].cnt[a[l] - 'a']++;
        if (l == r)
            return;
        int mid = (l + r) >> 1;
        build(k * 2, l, mid);
        build(k * 2 + 1, mid + 1, r);
        pushup(k);
    }

    void update(int k, int l, int r, int v) {
        // cerr << k << " " << l << " " << r << " " << v << " " << tr[k].l << " " << tr[k].r << endl;
        if (tr[k].l >= l && tr[k].r <= r)
            return lazy(k, v);
        pushdown(k);
        int mid = (tr[k].l + tr[k].r) >> 1;
        int lc = k * 2, rc = k * 2 + 1;
        if (r <= mid)
            update(lc, l, r, v);
        else if (l > mid)
            update(rc, l, r, v);
        else
            update(lc, l, mid, v), update(rc, mid + 1, r, v);
        pushup(k);
    }

    vector<int> query(int k, int l, int r) {
        if (tr[k].l >= l && tr[k].r <= r)
            return tr[k].cnt;
        pushdown(k);
        int mid = (tr[k].l + tr[k].r) >> 1;
        int lc = k * 2, rc = k * 2 + 1;
        if (r <= mid)
            return query(lc, l, r);
        else if (l > mid)
            return query(rc, l, r);
        else
            return query(lc, l, mid) + query(rc, mid + 1, r);
    }
} seg;

void color(int l, int r, map<int, int>& col) {
    int sum = 0;
    for (auto [k, v] : col) {
        if (v == 0) continue;
        sum += v;
        seg.update(1, l + sum - v, l + sum - 1, k);
        seg.update(1, r - sum + 1, r - sum + v, k);
    }
}

signed main() {
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);

    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);

    cin >> n >> m;
    cin >> a;
    a = " " + a;

    seg.build(1, 1, n);

    rep(i, 0, m - 1) {
        int l, r;
        cin >> l >> r;
        auto cnt = seg.query(1, l, r);
        int odd = 26;
        rep(j, 0, 25) {
            if (cnt[j] % 2 == 1) {
                if (odd != 26) {
                    odd = 27;
                    break;
                }
                odd = j;
            }
        }
        if (odd == 27) continue;
        map<int, int> col;
        if (odd == 26) {
            rep(j, 0, 25) col[j] = cnt[j] / 2;
        } else {
            rep(j, 0, 25) {
                if (j != odd) {
                    col[j] = cnt[j] / 2;
                }
            }
            int mid = l + r >> 1;
            seg.update(1, mid - cnt[odd] / 2, mid + cnt[odd] / 2, odd);
        }
        color(l, r, col);
    }

    rep(i, 1, n) {
        auto cnt = seg.query(1, i, i);
        for (int j = 0; j < 26; j++) {
            if (cnt[j]) cout << (char)(j + 'a');
        }
    }
    cout << endl;

    return 0;
}
2024/10/13 13:06
加载中...