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

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

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

2019-11-10 19:51:28
字體:
來源:轉載
供稿:網友

題目鏈接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
国产精品18久久久久久麻辣| 国产精品在线看| 精品五月天久久| 97欧美精品一区二区三区| 日韩一区视频在线| 国产精品视频男人的天堂| 26uuu另类亚洲欧美日本老年| 久久九九全国免费精品观看| 亚洲缚视频在线观看| 国产亚洲精品成人av久久ww| 国产精品爱啪在线线免费观看| 久久成人精品一区二区三区| 欧美激情国产高清| 中文字幕精品一区二区精品| 久久99久久99精品免观看粉嫩| 美日韩精品免费视频| 精品视频久久久| 国产精品亚洲自拍| 高跟丝袜一区二区三区| 在线观看日韩专区| 久久影院在线观看| 日韩精品视频在线| 亚洲一区二区三区香蕉| 国产不卡精品视男人的天堂| 国产在线精品播放| 欧美激情一区二区三区成人| 在线看片第一页欧美| 国产三级精品网站| 国产精品一区二区久久久| 久久久久久一区二区三区| 欧美诱惑福利视频| 成人444kkkk在线观看| 亚洲性生活视频在线观看| 亚洲片国产一区一级在线观看| 亚洲一区二区免费| 欧美国产日产韩国视频| 美女999久久久精品视频| 欧美色videos| 96精品久久久久中文字幕| 欧美精品一本久久男人的天堂| 欧美国产精品日韩| 欧美激情在线观看| 成人情趣片在线观看免费| 国产精品第1页| 色与欲影视天天看综合网| 97成人精品区在线播放| 欧美成人激情图片网| 91免费欧美精品| 日韩美女在线观看| 午夜精品国产精品大乳美女| 日韩电影中文字幕在线观看| 国产精品一区二区久久精品| 色先锋资源久久综合5566| 欧美www在线| 麻豆国产精品va在线观看不卡| 久久精品亚洲热| 成人免费视频xnxx.com| 亚洲女在线观看| 欧美电影在线观看高清| 亚洲一区二区在线| 久久久久久亚洲精品中文字幕| 中文字幕日韩视频| 亚洲欧美日韩网| 成人做爰www免费看视频网站| 亚洲图片欧美午夜| 欧美精品18videos性欧| 91av在线播放视频| 国产97在线亚洲| 亚洲国内精品视频| 久久免费视频网站| 色综合天天狠天天透天天伊人| 国产精品欧美激情| 国产精品精品久久久| 青青青国产精品一区二区| 国产精品一区久久久| 国产91露脸中文字幕在线| 精品视频在线导航| 岛国av在线不卡| 欧美精品免费在线观看| 国产欧亚日韩视频| 国产日韩专区在线| 国产精品第一第二| 疯狂蹂躏欧美一区二区精品| 九九久久久久久久久激情| 亚洲偷熟乱区亚洲香蕉av| 国产精品男女猛烈高潮激情| 午夜精品一区二区三区在线视频| 日本高清不卡在线| 亚洲精品在线看| 97av在线视频| 久久久久久国产| 91夜夜揉人人捏人人添红杏| 亚洲成人网av| 精品视频在线播放色网色视频| 国产精品自产拍在线观看| 国产精品无av码在线观看| 亚洲中国色老太| 色香阁99久久精品久久久| 俺去啦;欧美日韩| 欧美亚洲伦理www| 在线国产精品视频| 国产婷婷成人久久av免费高清| 亚洲 日韩 国产第一| 97色在线观看| 国产亚洲精品成人av久久ww| 精品爽片免费看久久| 成人xvideos免费视频| 国产一区二区精品丝袜| 国产脚交av在线一区二区| 久久99精品久久久久久琪琪| 日韩精品视频中文在线观看| 亚洲成人黄色在线| 国产一区二区色| 欧美自拍视频在线观看| 91精品中国老女人| 精品国产一区二区三区久久狼黑人| 91精品国产成人www| 日韩有码视频在线| 国产亚洲一区二区在线| 日韩在线免费视频观看| 亚洲激情成人网| 中文字幕亚洲情99在线| 国产高清视频一区三区| 一本色道久久88亚洲综合88| 中文字幕亚洲在线| 亚洲精品国产suv| 久久综合五月天| 亚洲精品久久久久久下一站| 亚洲天堂影视av| 91福利视频在线观看| 亚洲精品美女在线| 国产精品电影久久久久电影网| 欧美日韩激情小视频| 黑人巨大精品欧美一区免费视频| 日韩成人中文字幕在线观看| 亚洲欧美日韩国产精品| 91成人免费观看网站| 亚洲精品aⅴ中文字幕乱码| 亚洲成人a级网| 九九热精品视频国产| 亚洲字幕在线观看| 国产欧美精品一区二区三区-老狼| 国产91精品高潮白浆喷水| 国产精品入口免费视频一| 国产亚洲成av人片在线观看桃| 欧美尺度大的性做爰视频| 成人在线观看视频网站| 4438全国亚洲精品在线观看视频| 国产精品久久久久久网站| 亚洲美女免费精品视频在线观看| 2019中文字幕免费视频| 久久久久久亚洲精品| 亚洲成年网站在线观看| 欧美性猛交xxxx免费看漫画| 亚洲欧美国产精品久久久久久久| 欧美久久精品午夜青青大伊人| 亚洲www永久成人夜色| 亚洲国产欧美在线成人app| 日韩欧美在线字幕| 亚洲全黄一级网站| 精品视频久久久| 亚洲国产精品久久久久秋霞蜜臀| 欧美成人精品不卡视频在线观看| 欧美激情乱人伦|