HDU 5372 Segment Game (樹狀數組)

題意是指第i此插入操做,插入一條長度爲i的線段,左端點在b[i],刪除某一條線段,問每次插入操做時,被當前線段徹底覆蓋的線段的條數。ios

題解:對於新插入的線段,查詢有多少個線段左端點大於等於該線段的左端點。 再查詢有多少個線段的右端點大於該線段右端點, 二者之差就是答案。用兩個樹狀數組搞定。時間複雜度nlogn數組

 

因爲座標範圍很大,須要離散。ui

 

#pragma comment(linker, "/STACK:1677721600")
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <cmath>
#include <ctime>
#include <bitset>
#include <vector>
#include <cstdio>
#include <cctype>
#include <cstdarg>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
#define INF 0x3f3f3f3f
#define inf (-((LL)1<<40))
#define root 1, 1, n
#define lc (k << 1)
#define rc (k << 1 | 1)
#define middle ((L + R) >> 1)
#define lson k<<1, L, (L + R)>>1
#define rson k<<1|1,  ((L + R)>>1) + 1, R
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define mem(a, b) memset(a, b, sizeof(a))
#define FIN freopen("in.txt", "r", stdin)
#define FOUT freopen("out.txt", "w", stdout)
#define rep(i, a, b) for(int i = a; i <= b; i ++)
#define dec(i, a, b) for(int i = a; i >= b; i --)

//typedef __int64 LL;
//typedef long long LL;
typedef pair<int, int> Pair;
const int MAXN = 200000 + 100;
const int MAXM = 110000;
const double eps = 1e-10;
//LL MOD = 1000000007;

struct Operator {
    int type, lb;//全部操做,lb表示左邊界
}op[MAXN];
int c1[MAXN], c2[MAXN], n;//兩個樹狀數組
int h1[MAXN], h2[MAXN], L[MAXN];//用於hash,L[i]表示第i次詢問的左邊界

int lowbit(int x) { return x & (-x); }

void update(int *c, int n, int k, int v) {
    while(k <= n) {
        c[k] += v;
        k += lowbit(k);
    }
}

int query(int *c, int k) {
    int ans = 0;
    while(k > 0) {
        ans += c[k];
        k -= lowbit(k);
    }
    return ans;
}

int main()
{
#ifndef ONLINE_JUDGE
    FIN;
//    FOUT;
#endif
    int cas = 0;
    while(~scanf("%d", &n)) {
        mem0(c1); mem0(c2);
        int cnt = 0, sz1 = 0, sz2 = 0;
        rep (i, 1, n) {
            scanf("%d %d", &op[i].type, &op[i].lb);
            if(op[i].type == 0) {
                cnt ++;
                h1[sz1++] = op[i].lb;
                h2[sz2++] = op[i].lb + cnt;
                L[cnt] = op[i].lb;
            }
        }

        sort(h1, h1 + sz1); sz1 = unique(h1, h1 + sz1) - h1;
        sort(h2, h2 + sz2); sz2 = unique(h2, h2 + sz2) - h2;
        printf("Case #%d:\n", ++cas);

        cnt = 0;
        rep (i, 1, n) {
            if( !op[i].type ) { //(cnt_seg - query(c1, lb - 1)) - (cnt_seg - query(c2, rb)) = q2(rb) - q1(lb - 1)
                ++cnt;
                int lb = lower_bound(h1, h1 + sz1, op[i].lb) - h1 + 1;
                int rb = lower_bound(h2, h2 + sz2, op[i].lb + cnt) - h2 + 1;
                printf("%d\n", query(c2, rb) - query(c1, lb - 1));
                update(c1, sz1, lb, 1);
                update(c2, sz2, rb, 1);
            }
            else {
                update(c1, sz1, lower_bound(h1, h1 + sz1, L[op[i].lb]) - h1 + 1, -1);
                update(c2, sz2, lower_bound(h2, h2 + sz2, L[op[i].lb] + op[i].lb) - h2 + 1, -1);
            }
        }
    }
    return 0;
}
相關文章
相關標籤/搜索