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

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

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

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

題目鏈接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
欧美日本啪啪无遮挡网站| 国产精品爽爽爽| 色哟哟亚洲精品一区二区| 亚洲欧美日韩成人| 国产精品va在线播放我和闺蜜| 久久综合亚洲社区| 精品久久久久久久中文字幕| 国产欧美日韩综合精品| 精品二区三区线观看| 91tv亚洲精品香蕉国产一区7ujn| 亚洲最大福利视频网| 91免费的视频在线播放| 色噜噜国产精品视频一区二区| 国产欧美一区二区三区在线| 亚洲**2019国产| 欧美日韩亚洲91| 欧美多人乱p欧美4p久久| 搡老女人一区二区三区视频tv| 日韩久久精品成人| 久久天堂av综合合色| 亚洲精品成人免费| 久久精品国产99国产精品澳门| 久久综合网hezyo| 91香蕉国产在线观看| 91欧美精品午夜性色福利在线| 日韩中文字幕国产| 国产手机视频精品| 91精品91久久久久久| 7m第一福利500精品视频| 欧美在线观看日本一区| 主播福利视频一区| 欧美另类极品videosbestfree| 久久久999国产精品| 国产日韩在线播放| 亚洲免费av电影| 亚洲一区二区三区在线视频| 国产精品专区第二| www国产亚洲精品久久网站| 欧美日韩在线视频一区| 日韩中文字幕在线播放| 精品久久久久久国产| 欧美黑人又粗大| 91久久夜色精品国产网站| 久久精品成人欧美大片古装| 亚洲毛片在线免费观看| 亚洲欧美一区二区激情| 久久久久国产一区二区三区| 91免费国产视频| 色噜噜国产精品视频一区二区| 国产精品免费一区豆花| 91久久久久久久久久久久久| 久久影院资源站| 丰满岳妇乱一区二区三区| 神马久久久久久| 欧美性开放视频| 亚洲成人黄色在线| 日本久久久久久久久| 美女999久久久精品视频| 精品视频9999| 亚洲激情小视频| 亚洲国产精品成人va在线观看| 精品国模在线视频| 亚洲激情久久久| 久久亚洲一区二区三区四区五区高| 国产一区深夜福利| 久久久最新网址| 亚洲高清一二三区| 久久精品99无色码中文字幕| 国产欧美精品在线| 亚洲欧美在线磁力| 国产精品91视频| 大伊人狠狠躁夜夜躁av一区| 国产精品免费视频久久久| 日韩福利视频在线观看| 亚洲人成五月天| 日韩av免费网站| 日本三级久久久| 精品欧美一区二区三区| 日本精品视频在线| 中文字幕亚洲一区| 欧美成人免费全部观看天天性色| 国产日产欧美精品| 亚洲精品丝袜日韩| 国产精品久久久久av| 中文字幕亚洲激情| 亚洲美女精品久久| 欧美激情va永久在线播放| 久久91亚洲精品中文字幕| 日韩高清人体午夜| 久久久久久噜噜噜久久久精品| 国产91精品视频在线观看| 97在线视频免费播放| 国产精品黄视频| 国产精品成人av性教育| 欧美日本精品在线| 色悠久久久久综合先锋影音下载| 久久久噜噜噜久久久| 成人夜晚看av| 亚洲精品av在线| 日本成人免费在线| 国产精品一二三视频| 欧美极品美女视频网站在线观看免费| 欧美激情中文字幕乱码免费| 久久精品亚洲热| 国产日韩在线观看av| 日韩美女免费视频| 在线观看视频亚洲| 亚洲性夜色噜噜噜7777| 国产精品视频999| 一区二区福利视频| 91久久国产综合久久91精品网站| 欧美激情免费看| 国产精品免费久久久| 日韩中文理论片| 高清欧美性猛交xxxx| 亚洲www在线观看| 欧美日韩国产一区二区| 伊人久久精品视频| 国产一区二区三区在线播放免费观看| 国产大片精品免费永久看nba| 久久99热精品这里久久精品| 国内外成人免费激情在线视频| 欧洲成人在线视频| 69视频在线播放| 午夜精品www| 精品女同一区二区三区在线播放| 国产精品国内视频| 欧美大片在线看| 视频在线观看一区二区| 亚洲黄色av女优在线观看| 国产精品美女午夜av| 日本精品久久中文字幕佐佐木| 精品国产一区二区三区久久狼5月| 亚洲韩国欧洲国产日产av| 91免费视频国产| 欧美成人免费播放| 久久精品色欧美aⅴ一区二区| 成人高h视频在线| 高清亚洲成在人网站天堂| 久久久国产在线视频| 欧美日韩国产成人| 欧美性精品220| 国产精品嫩草影院久久久| 欧美成人性生活| 成人午夜在线影院| 91欧美日韩一区| 久久99亚洲热视| 欧美天天综合色影久久精品| 亚洲一区二区三区777| 成人国内精品久久久久一区| 91视频国产高清| 国产一区二区三区丝袜| 日韩免费在线视频| 亚洲无限乱码一二三四麻| 亚洲丝袜一区在线| 亚洲精品一区中文字幕乱码| 伦伦影院午夜日韩欧美限制| 国产精品成人在线| 国内精品一区二区三区| 亚洲成人a级网| 精品免费在线视频| 久久久午夜视频| 亚洲第一页在线| 色综合伊人色综合网站|