亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

gym-101138D(后綴和,莫隊算法,容斥原理,好題)

2019-11-10 17:31:35
字體:
來源:轉載
供稿:網友

題目鏈接D. Strange Queriestime limit per test3 secondsmemory limit per test256 megabytesinputstandard inputoutputstandard output

You are given an array with n integers a1,?a2,?...,?an, and q queries to answer.

Each query consists of four integers l1, r1, l2 and r2. Your task is to count the number of pairs of indices (i,?j) satisfying the following conditions:

ai?=?ajl1?≤?i?≤?r1l2?≤?j?≤?r2Input

The first line of the input contains an integer n (1?≤?n?≤?50?000) — the size of the given array.

The second line contains n integers a1,?a2,?...,?an (1?≤?ai?≤?n).

The third line contains an integer q (1?≤?q?≤?50?000) — the number of queries.

Each of the next q lines contains four integers l1, r1, l2, r2 (1?≤?l1?≤?r1?≤?n, 1?≤?l2?≤?r2?≤?n), describing one query.

Output

For each query count the number of sought pairs of indices (i,?j) and PRint it in a separate line.

Examplesinput
71 5 2 1 7 2 281 3 4 52 3 5 71 4 3 72 6 4 71 6 2 53 3 6 74 5 1 42 3 4 5output
12566220

題意簡明。

題解:

使用莫隊算法

假設當前左右指針分別為l和r,一共n個數

對于指針l,維護一個后綴[l,n],算這個后綴每個數出現次數。

對于指針r,維護一個后綴(r,n]算這個后綴每個數出現次數。

對區間[l,r)維護[l,n]和[r,n]中相等的數的對數。

假設區間[l,r)的答案為f(l,r).

那么,對于詢問l1,r1,l2,r2, 答案是f(l1,l2)-f(l1,r2+1)-f(r1+1,l2)+f(r1+1,r2+1).

#include<iostream>#include<cstdio>#include<algorithm>#include<cstring>#include<vector>#include<queue>#include<stack>#include<cmath>using namespace std;#define rep(i,a,n) for (int i=a;i<n;i++)#define per(i,a,n) for (int i=n-1;i>=a;i--)#define pb push_back#define fi first#define se secondtypedef vector<int> VI;typedef long long ll;typedef pair<int,int> PII;const int inf=0x3fffffff;const ll mod=1000000007;const int maxn=50000+100;int unit;struct node{    int l,r,id,k;    bool Operator <(const node&b) const{        if(l/unit==b.l/unit) return r<b.r;        else return l/unit<b.l/unit;    }    node(int x=0,int y=0):l(x),r(y) {}}a[maxn*4];int m=0,n;ll ans[maxn];int num[maxn];ll cnt[2][maxn];ll res;void solve(){    sort(a,a+m);    memset(cnt,0,sizeof(cnt));    memset(ans,0,sizeof(ans));    int l=n+1,r=n+1;   //    res=0;    rep(i,0,m)    {        while(l<a[i].l)        {            res-=1ll*cnt[0][num[l]]*cnt[1][num[l]];            cnt[0][num[l]]--;            res+=1ll*cnt[0][num[l]]*cnt[1][num[l]];            l++;        }        while(l>a[i].l)        {            l--;            res-=1ll*cnt[0][num[l]]*cnt[1][num[l]];            cnt[0][num[l]]++;            res+=1ll*cnt[0][num[l]]*cnt[1][num[l]];        }        while(r<a[i].r)        {            res-=1ll*cnt[1][num[r]]*cnt[0][num[r]];            cnt[1][num[r]]--;            res+=1ll*cnt[1][num[r]]*cnt[0][num[r]];            r++;        }        while(r>a[i].r)        {            r--;            res-=1ll*cnt[1][num[r]]*cnt[0][num[r]];            cnt[1][num[r]]++;            res+=1ll*cnt[1][num[r]]*cnt[0][num[r]];        }        ans[a[i].id]+=a[i].k*res;    }}int main(){    scanf("%d",&n);    unit=(int)sqrt(n);    rep(i,1,n+1) scanf("%d",&num[i]);    int q;    scanf("%d",&q);    rep(i,0,q)    {        int l1,r1,l2,r2;        scanf("%d%d%d%d",&l1,&r1,&l2,&r2);        r1++,r2++;        a[m]=node(l1,l2),a[m].id=i,a[m].k=1;        a[++m]=node(l1,r2),a[m].id=i,a[m].k=-1;        a[++m]=node(r1,l2),a[m].id=i,a[m].k=-1;        a[++m]=node(r1,r2),a[m].id=i,a[m].k=1;        m++;    }    solve();    rep(i,0,q)    printf("%lld/n",ans[i]);    return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲视频一区二区| 中文字幕欧美日韩精品| 精品女厕一区二区三区| 在线播放国产一区二区三区| 91系列在线观看| 正在播放亚洲1区| 欧美精品成人在线| 麻豆一区二区在线观看| 欧美猛交ⅹxxx乱大交视频| 亚洲精品大尺度| 91在线看www| 岛国视频午夜一区免费在线观看| 岛国av午夜精品| 国产成人在线视频| 日本精品久久久久影院| 亚洲人免费视频| 亚洲女人天堂av| 欧美亚洲伦理www| 亚洲影院高清在线| 欧美日韩国产成人在线观看| 国产精品极品美女粉嫩高清在线| 国产极品精品在线观看| 欧美日韩在线第一页| 国产网站欧美日韩免费精品在线观看| 欧美精品精品精品精品免费| 亚洲91精品在线观看| 精品久久香蕉国产线看观看亚洲| 91av在线网站| 日韩一级裸体免费视频| 亚洲色图激情小说| 中文字幕亚洲一区二区三区| 成人激情视频在线观看| 国产一区香蕉久久| 久久亚洲欧美日韩精品专区| 亚洲三级免费看| 欧美国产视频一区二区| 亚洲美女动态图120秒| 欧美性生交xxxxxdddd| 在线观看亚洲视频| 亚洲欧美色图片| 亚洲精品日韩av| 8x拔播拔播x8国产精品| 欧美xxxx做受欧美.88| 国产精品扒开腿爽爽爽视频| 日日狠狠久久偷偷四色综合免费| 久久免费视频网| 日韩欧美有码在线| 亚洲黄色在线观看| 91精品国产色综合久久不卡98口| 亚洲第一福利网站| 国产成人福利夜色影视| 亚洲综合最新在线| www.日韩.com| 精品国产成人在线| 久久亚洲私人国产精品va| 亚洲美女视频网站| 日韩在线观看精品| 成人春色激情网| 国产一区二区三区直播精品电影| 日韩av电影手机在线| 两个人的视频www国产精品| 91国语精品自产拍在线观看性色| 亚洲成人av片在线观看| 这里只有精品丝袜| 亚洲天堂av在线免费| 国产成人免费av电影| 亚洲综合在线中文字幕| 久久久成人精品| 日韩av网址在线| 亚洲香蕉av在线一区二区三区| 久久激情五月丁香伊人| 国产精品电影网站| 久久成人在线视频| 日韩一区二区三区国产| 亚洲欧美日本另类| 成人黄色免费片| 国产精品444| 国产视频精品在线| 国产小视频国产精品| 91在线视频免费| 久久99精品久久久久久琪琪| 国产在线精品一区免费香蕉| 久久大大胆人体| 欧美成人全部免费| 少妇精69xxtheporn| 日韩成人性视频| www.日韩av.com| 欧美一级黑人aaaaaaa做受| 91久久国产婷婷一区二区| 日韩国产高清污视频在线观看| 国产成人精品久久| 成人免费高清完整版在线观看| 国产精品入口日韩视频大尺度| 中文字幕不卡av| 91亚洲精品一区二区| 中文字幕亚洲综合| 欧美日本黄视频| 欧美日韩第一页| 久久亚洲精品中文字幕冲田杏梨| 欧美激情视频网站| 亚洲精选一区二区| 亚洲精品www久久久| 亚洲精品国产精品国自产在线| 26uuu国产精品视频| 欧美日韩国产成人高清视频| 中文字幕亚洲二区| 欧美成人精品不卡视频在线观看| 欧美高清在线播放| 狠狠久久亚洲欧美专区| 中文字幕日韩av电影| 精品久久久精品| 8050国产精品久久久久久| 精品国产一区av| 北条麻妃一区二区三区中文字幕| 国产一区私人高清影院| 色综合亚洲精品激情狠狠| 久久久久久91| 两个人的视频www国产精品| 久久久久亚洲精品成人网小说| 日韩一级黄色av| 精品久久久久久久久久国产| 精品自拍视频在线观看| xxx一区二区| 97av在线视频免费播放| 欧洲成人性视频| 狠狠爱在线视频一区| 久久成人精品电影| 国产日韩一区在线| 一本色道久久88亚洲综合88| 这里只有精品久久| 九九综合九九综合| 在线丨暗呦小u女国产精品| 91精品久久久久久久| 国产欧美久久久久久| 日韩在线高清视频| 成人xxxx视频| 亚洲精品国产精品自产a区红杏吧| 亚洲精品白浆高清久久久久久| 福利一区福利二区微拍刺激| 日韩国产欧美精品一区二区三区| 欧美成人精品影院| 亚洲黄色av女优在线观看| 亚洲尤物视频网| 97精品在线观看| 国产成人在线亚洲欧美| 大伊人狠狠躁夜夜躁av一区| 97在线精品视频| 91免费的视频在线播放| 欧美精品久久久久a| 国产精品第10页| y97精品国产97久久久久久| 成人两性免费视频| 91精品国产九九九久久久亚洲| 欧美成人免费在线观看| 亚洲一级一级97网| 国产一区二区在线免费视频| 一本色道久久综合亚洲精品小说| 欧美丝袜一区二区| 成人黄色av播放免费| 久久免费福利视频| www国产亚洲精品久久网站| 欧美成人午夜激情| 欧美中文字幕视频在线观看| 亚洲免费精彩视频|