zoukankan      html  css  js  c++  java
  • BZOJ3236 [Ahoi2013]作业 【莫队 + 树状数组】

    题目链接

    BZOJ3236

    题解

    没想到这题真的是如此暴力

    #include<algorithm>
    #include<iostream>
    #include<cstring>
    #include<cstdio>
    #include<cmath>
    #include<map>
    #define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
    #define REP(i,n) for (int i = 1; i <= (n); i++)
    #define mp(a,b) make_pair<int,int>(a,b)
    #define cls(s) memset(s,0,sizeof(s))
    #define cp pair<int,int>
    #define LL long long int
    #define lbt(x) (x & -x)
    using namespace std;
    const int maxn = 100005,maxm = 3000005,INF = 1000000000;
    inline int read(){
    	int out = 0,flag = 1; char c = getchar();
    	while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();}
    	while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();}
    	return out * flag;
    }
    int n,m,a[maxm],b[maxm],bi,B,tot,ans1[maxm],ans2[maxm];
    struct Que{int l,r,a,b,bl,id;}q[maxm];
    inline bool operator <(const Que& a,const Que& b){
    	return a.bl == b.bl ? a.r < b.r : a.l < b.l;
    }
    int getn(int x){return lower_bound(b + 1,b + 1 + tot,x) - b;}
    int bac[maxm];
    struct BIT{
    	int s[maxm];
    	void add(int u,int v){while (u <= tot) s[u] += v,u += lbt(u);}
    	int query(int u){int re = 0; while (u) re += s[u],u -= lbt(u); return re;}
    	int sum(int l,int r){return query(r) - query(l - 1);}
    }T1,T2;
    void solve(){
    	sort(q + 1,q + 1 + m);
    	int L = q[1].l,R = q[1].r;
    	for (int i = L; i <= R; i++){
    		T1.add(a[i],1);
    		if (!bac[a[i]]) T2.add(a[i],1);
    		bac[a[i]]++;
    	}
    	ans1[q[1].id] = T1.sum(q[1].a,q[1].b);
    	ans2[q[1].id] = T2.sum(q[1].a,q[1].b);
    	for (int i = 2; i <= m; i++){
    		while (L != q[i].l || R != q[i].r){
    			if (L < q[i].l){
    				bac[a[L]]--;
    				T1.add(a[L],-1);
    				if (!bac[a[L]]) T2.add(a[L],-1);
    				L++;
    			}
    			if (L > q[i].l){
    				L--;
    				T1.add(a[L],1);
    				if (!bac[a[L]]) T2.add(a[L],1);
    				bac[a[L]]++;
    			}
    			if (R < q[i].r){
    				R++;
    				T1.add(a[R],1);
    				if (!bac[a[R]]) T2.add(a[R],1);
    				bac[a[R]]++;
    			}
    			if (R > q[i].r){
    				bac[a[R]]--;
    				T1.add(a[R],-1);
    				if (!bac[a[R]]) T2.add(a[R],-1);
    				R--;
    			}
    		}
    		ans1[q[i].id] = T1.sum(q[i].a,q[i].b);
    		ans2[q[i].id] = T2.sum(q[i].a,q[i].b); 
    	}
    	for (int i = 1; i <= m; i++)
    		printf("%d %d
    ",ans1[i],ans2[i]);
    }
    int main(){
    	n = read(); m = read(); B = (int)sqrt(n) + 1;
    	REP(i,n) a[i] = b[++bi] = read();
    	REP(i,m){
    		q[i].l = read(); q[i].r = read(); q[i].bl = q[i].l / B;
    		b[++bi] = q[i].a = read();
    		b[++bi] = q[i].b = read();
    		q[i].id = i;
    	}
    	sort(b + 1,b + 1 + bi); tot = 1;
    	for (int i = 2; i <= bi; i++) if (b[i] != b[tot]) b[++tot] = b[i];
    	for (int i = 1; i <= n; i++) a[i] = getn(a[i]);
    	for (int i = 1; i <= m; i++) q[i].a = getn(q[i].a),q[i].b = getn(q[i].b);
    	solve();
    	return 0;
    }
    
    
  • 相关阅读:
    洛谷T44252 线索_分治线段树_思维题
    css 迷惑的position
    【二次元的CSS】—— 用 DIV + CSS3 画大白(详解步骤)
    直接使用sublime编译stylus
    w3schools网站的HTML教程之HTML编辑器
    【二次元的CSS】—— 纯CSS3做的能换挡的电扇
    《JavaScript Dom编程艺术》读书笔记(二)
    JQuery基础修炼-样式篇
    Vue.js 开发实践:实现精巧的无限加载与分页功能
    web前端教程《每日一题》(1-99)完结
  • 原文地址:https://www.cnblogs.com/Mychael/p/9044124.html
Copyright © 2011-2022 走看看