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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)

發(fā)布時(shí)間:2025/3/15 编程问答 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比烏斯反演+數(shù)論分塊)

手動(dòng)博客搬家: 本文發(fā)表于20171216 13:34:20, 原地址https://blog.csdn.net/suncongbo/article/details/78819470

URL: (Luogu)https://www.luogu.org/problem/show?pid=3455
(BZOJ)http://www.lydsy.com/JudgeOnline/problem.php?id=1101

題目大意:
有t次詢問(wèn)(\(t\le5e4\)), 每次給定a,b,d, 詢問(wèn)有多少對(duì)(x,y)滿足x<=a, y<=b, gcd(a,b)=d. 0<=d<=a,b<=5e4

思路分析:
首先,需要注意的是,要特殊處理\(d=0\)的情況,答案為0.
對(duì)于\(d\ge1\), 采用莫比烏斯反演解決:
先將a/=d, b/=d, 因此只需求gcd(x,y)=1的數(shù)的對(duì)數(shù)。
令F[i]表示\(1\le x\le a,1\le y\le b\)\(i|gcd(x,y)\)的a,b總數(shù), f[i]表示gcd(x,y)=i的數(shù)的對(duì)數(shù)(此處a,b都已經(jīng)除以d).因此問(wèn)題轉(zhuǎn)化為求f(1).
根據(jù)莫比烏斯反演公式:\[F(n)=\sum_{n|x} f(x), f(n)=\sum_{n|x} F(x)\mu(\frac{x}{n})\]
因此,\(f(1)=\sum_{1|x} F(x)\mu(x)\)
而顯然我們有\(F(x)=[\frac{a}{x}][\frac{b}{x}]\), 因此可以\(O(1)\)地求出F(x), 也就可以\(O(min(a,b))\)地求出f(1)了。(莫比烏斯反演函數(shù)\(\mu(x)\)可在線性篩中求出)
可是這樣還不夠。算算復(fù)雜度,發(fā)現(xiàn)會(huì)TLE.
注意到一個(gè)性質(zhì): 對(duì)于\(x\le\sqrt{a}\), \([\frac{a}{x}]\)的值變化得很快,\([\frac{a}{x}]\)的變化速度遠(yuǎn)高于\(x\)的變化速度。而對(duì)于\(x\gt\sqrt{a}\), \([\frac{a}{x}]\)的值變化得很慢, 遠(yuǎn)低于\(x\)的變化速度。因此,我們可以求出所有使得\([\frac{a}{x}]\)的值變化的點(diǎn)x, 共有\(O(\sqrt{n})\)個(gè)(實(shí)際上帶一個(gè)常數(shù)2), 然后我們對(duì)b做同樣的操作。將所有影響\([\frac{a}{x}]\)\([\frac{b}{x}]\)的值的點(diǎn)都從小到大排序記錄下來(lái),處理莫比烏斯函數(shù)的前綴和, 每一個(gè)點(diǎn)代表一個(gè)區(qū)間,這個(gè)區(qū)間內(nèi)所有的數(shù)\([\frac{a}{x}]\)\([\frac{b}{x}]\)的值分別與這個(gè)數(shù)\([\frac{a}{x}]\)\([\frac{b}{x}]\)相等。然后這一段區(qū)間對(duì)答案的貢獻(xiàn)就是區(qū)間的\(\mu()\)之和乘以\([\frac{a}{x}][\frac{b}{x}]\).

代碼實(shí)現(xiàn)

#include<cstdio> #include<algorithm> #include<cmath> using namespace std;const int N = 5e4; const int NN = 317; int p[N+2]; bool f[N+2]; int mu[N+2]; int s[N+2]; int g[(NN<<2)+2]; int h[(NN<<2)+2]; int a,b,d,m;void Mobius() {f[1] = true; mu[1] = 1; m = 0;for(int i=2; i<=N; i++){if(!f[i]) {p[++m] = i; mu[i] = -1;}for(int j=1; p[j]*i<=N; j++){f[p[j]*i] = true;if(i%p[j]==0){mu[i*p[j]] = 0;break;}else mu[i*p[j]] = -mu[i];}} }void merge(int aa,int bb) {int i = 1,j = (aa<<1)+1,k = 1;while(i<=(aa<<1) && j<=(aa<<1)+(bb<<1)){if(h[i]<h[j]) g[k++] = h[i++];else g[k++] = h[j++];}while(i<=(aa<<1)) g[k++] = h[i++];while(j<=(aa<<1)+(bb<<1)) g[k++] = h[j++]; }int main() {int t; scanf("%d",&t);Mobius(); s[0] = 0;for(int i=1; i<=N; i++) s[i] = s[i-1]+mu[i];while(t--){scanf("%d%d%d",&a,&b,&d);if(d==0) {printf("0\n"); continue;}if(a>b) swap(a,b);a /= d; b /= d;int aa = (int)sqrt(a),bb = (int)sqrt(b);long long ans = 0ll;for(int i=1; i<=aa; i++) h[i] = i;for(int i=aa; i>=1; i--) h[(aa<<1)-i+1] = a/i;//保證h[]在1~(aa<<1)范圍內(nèi)有序for(int i=1; i<=bb; i++) h[i+(aa<<1)] = i;for(int i=bb; i>=1; i--) h[(aa<<1)+(bb<<1)-i+1] = b/i;//保證h[]在1~(bb<<1)范圍內(nèi)有序merge(aa,bb);//將[1,aa<<1]與[aa<<1+1,aa<<1+bb<<1]歸并起來(lái)for(int i=1; i<=(aa<<1)+(bb<<1); i++){ans += (long long)(s[g[i]]-s[g[i-1]])*(a/g[i])*(b/g[i]);}printf("%lld\n",ans);}return 0; } 發(fā)表于 2018-12-26 22:54 suncongbo 閱讀(...) 評(píng)論(...) 編輯 收藏 刷新評(píng)論刷新頁(yè)面返回頂部

總結(jié)

以上是生活随笔為你收集整理的BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 天天射天天 | 麻豆av在线 | 男生插女生的网站 | 九九热这里有精品 | 国产又粗又爽视频 | 高清欧美性猛交 | 超碰日韩| 亚洲三级成人 | 熟妇五十路六十路息与子 | 少妇一级淫片免费播放 | 亚洲欧美综合色 | 国产三级全黄 | 黄色免费网站视频 | 中文字幕在线视频免费 | 国产第6页| 欧美大片一区二区 | 国产一区二区三区免费播放 | www.中文字幕.com| 极品美女高潮出白浆 | 久久无码专区国产精品s | 调教91| 日韩久久精品视频 | 欧美精品免费在线 | 丰满少妇大力进入 | 天堂色网| 中文字幕在线看高清电影 | 国产精品夜夜爽 | 色热热 | 欧美图片一区二区三区 | 亚洲一区二区三区无码久久 | 波多野结衣av在线免费观看 | 亚洲jizzjizz | 日日舔夜夜摸 | 亚洲AV成人无码电影在线观看 | 亚洲情在线 | 黄色特级毛片 | 亚洲黄色在线视频 | 欧美又大又硬又粗bbbbb | 懂色一区二区三区免费观看 | 欧美日韩精品在线播放 | 偷偷操99| 91丨九色丨蝌蚪丨对白 | 亚洲欧美另类日本 | 两个小y头稚嫩紧窄h文 | 2019国产精品| 成人特级毛片 | 国产欧美日韩精品一区二区三区 | 日韩系列在线 | ⅹxxxxhd亚洲日本hd老师 | 精品自拍偷拍视频 | 香蕉av在线| 99re在线国产 | 成人久久影院 | 男女视频国产 | 色婷婷婷婷| 免费亚洲一区 | 91丨九色丨丰满 | 尤物视频最新网址 | 欧美性天天影院 | 精品国内自产拍在线观看视频 | 日本在线看 | 好吊妞在线观看 | 日韩播放| 男生和女生差差视频 | 日韩欧美视频免费在线观看 | 国产无玛 | 亚洲国产成人精品女人 | 深夜久久| 男生吃小头头的视频 | 中文字幕11页中文字幕11页 | 国产精品视频全国免费观看 | 国产国语对白 | 欧美极品少妇×xxxbbb | 成人自拍视频在线 | 欧美成人精品欧美一级乱黄 | 少妇粉嫩小泬喷水视频www | 精品一区电影国产 | 自拍偷自拍亚洲精品播放 | 亚洲国产97 | 爱插美女网 | 日韩毛片高清在线播放 | 91亚洲国产成人精品性色 | 99r热| 最新国产黄色网址 | 性少妇mdms丰满hdfilm | 久久99网站 | 天天躁日日躁aaaxxⅹ | 日韩国产在线一区 | 欧美乱轮视频 | 免费无码av片在线观看 | 亚洲不卡电影 | 精品日本一区二区三区 | av无码精品一区二区三区宅噜噜 | 怒海潜沙秦岭神树 | 久久伊人免费 | 亚洲中文字幕一区二区在线观看 | 国产精品v日韩精品v在线观看 | 亚洲精品大片www | 91人妻一区二区 |