日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

BZOJ2038 : [2009国家集训队]小Z的袜子(hose)(莫队算法)

發布時間:2023/12/18 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BZOJ2038 : [2009国家集训队]小Z的袜子(hose)(莫队算法) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2038: [2009國家集訓隊]小Z的襪子(hose)
Time Limit: 20 Sec Memory Limit: 259 MB
Submit: 19269 Solved: 8851
[Submit][Status][Discuss]
Description
作為一個生活散漫的人,小Z每天早上都要耗費很久從一堆五顏六色的襪子中找出一雙來穿。終于有一天,小Z再也無法忍受這惱人的找襪子過程,于是他決定聽天由命……
具體來說,小Z把這N只襪子從1到N編號,然后從編號L到R(L 盡管小Z并不在意兩只襪子是不是完整的一雙,甚至不在意兩只襪子是否一左一右,他卻很在意襪子的顏色,畢竟穿兩只不同色的襪子會很尷尬。
你的任務便是告訴小Z,他有多大的概率抽到兩只顏色相同的襪子。當然,小Z希望這個概率盡量高,所以他可能會詢問多個(L,R)以方便自己選擇。

Input
輸入文件第一行包含兩個正整數N和M。N為襪子的數量,M為小Z所提的詢問的數量。接下來一行包含N個正整數Ci,其中Ci表示第i只襪子的顏色,相同的顏色用相同的數字表示。再接下來M行,每行兩個正整數L,R表示一個詢問。

Output
包含M行,對于每個詢問在一行中輸出分數A/B表示從該詢問的區間[L,R]中隨機抽出兩只襪子顏色相同的概率。若該概率為0則輸出0/1,否則輸出的A/B必須為最簡分數。(詳見樣例)

Sample Input
6 4

1 2 3 3 3 2

2 6

1 3

3 5

1 6

Sample Output
2/5

0/1

1/1

4/15

【樣例解釋】

詢問1:共C(5,2)=10種可能,其中抽出兩個2有1種可能,抽出兩個3有3種可能,概率為(1+3)/10=4/10=2/5。

詢問2:共C(3,2)=3種可能,無法抽到顏色相同的襪子,概率為0/3=0/1。

詢問3:共C(3,2)=3種可能,均為抽出兩個3,概率為3/3=1/1。

注:上述C(a, b)表示組合數,組合數C(a, b)等價于在a個不同的物品中選取b個的選取方案數。

【數據規模和約定】

30%的數據中 N,M ≤ 5000;

60%的數據中 N,M ≤ 25000;

100%的數據中 N,M ≤ 50000,1 ≤ L < R ≤ N,Ci ≤ N。

HINT
Source
版權所有者:莫濤

思路:
用數組flag[i] 記錄當前區間中已經有了多少個i數字。然后常規的莫隊轉移即可。

細節見代碼:

#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> #include <cmath> #include <queue> #include <stack> #include <map> #include <set> #include <vector> #include <iomanip> #define ALL(x) (x).begin(), (x).end() #define sz(a) int(a.size()) #define all(a) a.begin(), a.end() #define rep(i,x,n) for(int i=x;i<n;i++) #define repd(i,x,n) for(int i=x;i<=n;i++) #define pii pair<int,int> #define pll pair<long long ,long long> #define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0) #define MS0(X) memset((X), 0, sizeof((X))) #define MSC0(X) memset((X), '\0', sizeof((X))) #define pb push_back #define mp make_pair #define fi first #define se second #define eps 1e-6 #define gg(x) getInt(&x) #define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl using namespace std; typedef long long ll; ll gcd(ll a, ll b) {return b ? gcd(b, a % b) : a;} ll lcm(ll a, ll b) {return a / gcd(a, b) * b;} ll powmod(ll a, ll b, ll MOD) {ll ans = 1; while (b) {if (b % 2)ans = ans * a % MOD; a = a * a % MOD; b /= 2;} return ans;} inline void getInt(int* p); const int maxn = 50010; const int inf = 0x3f3f3f3f; /*** TEMPLATE CODE * * STARTS HERE ***/ pll ans[maxn]; ll Ans=0ll; int l=1; int r=0; struct node {int l,r,id; }a[maxn]; int pos[maxn]; int n,m; int len; bool cmp(node aa,node bb) {if(pos[aa.l]==pos[bb.l]){return aa.r<bb.r;}else{return pos[aa.l]<pos[bb.l];} } int col[maxn]; int flag[maxn]; void add(int x) {Ans+=1ll*flag[col[x]];flag[col[x]]++; } void del(int x) {flag[col[x]]--;Ans-=1ll*flag[col[x]]; } int main() {//freopen("D:\\code\\text\\input.txt","r",stdin);//freopen("D:\\code\\text\\output.txt","w",stdout);gg(n);gg(m);len=(int)(sqrt(n));repd(i,1,n){gg(col[i]);}repd(i,1,m){gg(a[i].l);gg(a[i].r);a[i].id=i;pos[i]=i/len;}sort(a+1,a+1+m,cmp);repd(i,1,m){while(l>a[i].l){l--;add(l);}while(r<a[i].r){r++;add(r);}while(l<a[i].l){del(l);l++;}while(r>a[i].r){del(r);r--;}ans[a[i].id].fi=Ans;ll temp=a[i].r-a[i].l+1;ans[a[i].id].se=(temp*(temp-1ll))>>1;}repd(i,1,m){if(!ans[i].fi){puts("0/1");continue;}ll g=gcd(ans[i].fi,ans[i].se);printf("%lld/%lld\n",ans[i].fi/g,ans[i].se/g);}return 0; }inline void getInt(int* p) {char ch;do {ch = getchar();} while (ch == ' ' || ch == '\n');if (ch == '-') {*p = -(getchar() - '0');while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 - ch + '0';}}else {*p = ch - '0';while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 + ch - '0';}} }

轉載于:https://www.cnblogs.com/qieqiemin/p/11365056.html

總結

以上是生活随笔為你收集整理的BZOJ2038 : [2009国家集训队]小Z的袜子(hose)(莫队算法)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 九九热精品免费视频 | 亚洲区综合 | 久久久久久久久久影视 | 欧洲在线观看 | 国产偷人 | 美女免费看片 | 福利视频二区 | ass极品国模人体欣赏 | 动漫美女无遮挡免费 | 欧美又粗又大xxxxbbbb疯狂 | 国产亚洲精久久久久久无码77777 | 别揉我奶头一区二区三区 | 五月婷婷久久久 | 少妇25p | 国产中文字幕一区二区 | 少妇一级淫片免费放播放 | av片亚洲 | 国产精品久久久久久久久动漫 | www.三级| 欧美人妖乱大交 | 最新中文字幕一区 | 欧美福利片在线观看 | 久久女同互慰一区二区三区 | 在线看片成人 | 欧美亚洲二区 | 中文字幕第一页亚洲 | 老女人一毛片 | 夜夜春很很躁夜夜躁 | 色撸撸在线观看 | 男人桶女人桶爽30分钟 | 色爽av| 日韩国产在线 | 九九热视频免费观看 | 青青草成人网 | 久久久久久久久久久久久久久久久久久 | 任你操精品 | 免费网站av | 欧美亚洲综合在线 | 肉大榛一进一出免费视频 | 狠狠操在线播放 | 黑人精品无码一区二区三区 | 日韩精品在线观看AV | 密桃成熟时在线观看 | 性淫bbwbbwbbw| 亚洲久草| 人体写真 福利视频 | 中文在线一区二区 | 一级黄色a | 黄色三级a | 欧美精品日韩在线 | 99色图| 就要操就要日 | 精品无码m3u8在线观看 | 轮番上阵免费观看在线电影 | 黑鬼大战白妞高潮喷白浆 | 午夜在线小视频 | 亚洲黄色在线网站 | 草久在线观看视频 | 91狠狠 | 91福利视频网 | 久久精品国产亚洲av麻豆图片 | 午夜伦伦电影理论片费看 | 中文有码在线观看 | 午夜影院一区二区 | 麻豆一区二区在线观看 | 日韩免费小视频 | 成人午夜视频免费看 | 麻豆极品 | 2021av视频 | 影音先锋男人资源网站 | 国产精品亚洲专区无码牛牛 | av天天看| a级片免费在线观看 | 中文第一页 | 黄色片免费的 | 成人区人妻精品一区二区网站 | 欧美精品做受xxx性少妇 | 欧洲人妻丰满av无码久久不卡 | 人人妻一区二区三区 | 亚洲欧美日韩天堂 | 日韩性生活视频 | 亚洲嫩草影院 | 自拍偷拍激情视频 | 99精品欧美| 国产手机视频在线 | 丝袜制服一区 | 国产欧美精品 | 国产69熟| 4438成人网| 欧美日韩在线一区二区 | 偷偷操av| 久久久久久一区二区 | 日韩人妻一区二区三区蜜桃视频 | 欧美日韩在线观看一区二区 | 欧美三级特黄 | 一区免费 | 天堂国产在线 | 亚洲一区国产 | www.五月天婷婷.com |