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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

又见莫比乌斯反演

發布時間:2024/4/11 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 又见莫比乌斯反演 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目:http://acm.uestc.edu.cn/#/problem/show/811

?

題意:給定兩個正整數和,其中,,求的值,其中。

?

分析:本題是典型的莫比烏斯反演問題。那么,怎么反演呢?

???? 首先,我們枚舉的所有值,根據以前學的莫比烏斯反演,可以很容易得到

?

?????,其中

?

???? 我們設

?

???? ,那么得到,反演后得到

?

???? 所以就是

?

???? 可以看出枚舉的所有因子遞歸下去就行。。。現在的關鍵問題是如何計算。

?

?????的表達式為

?

???? 由于不大,所以可以直接用自然數冪和,而在一段連續的區間值保持不變,思路跟下面這道題差不多。

?

???? 題目:http://blog.csdn.net/acdreamers/article/details/10249611

?

??????也就是說的時間復雜度為。加上遞歸的部分,本題總的時間復雜度為。

?

?

???? 代碼:

#include <iostream> #include <string.h> #include <stdio.h> #include <math.h>using namespace std; const int N = 50000005; typedef long long LL; const LL MOD = 1000000007;LL dp[N];LL mu(LL n,int k) {LL ans = 1;for(int i=0; i<k; i++){ans *= n;ans %= MOD;}return ans; }LL calc(LL n,int k) {if(k == 1) return ((n%MOD)*((n+1)%MOD))%MOD*500000004%MOD;if(k == 2){LL a = n % MOD;LL b = (n+1) % MOD;LL c = (2*n+1) % MOD;return a*b%MOD*c%MOD*166666668%MOD;}if(k == 3){LL t = ((n%MOD)*((n+1)%MOD))%MOD*500000004%MOD;return t * t % MOD;}if(k == 4){LL t = 6*mu(n,5)%MOD + 15*mu(n,4)%MOD + 10*mu(n,3)%MOD -n%MOD;t %= MOD;t += MOD;t %= MOD;t *= 233333335;t %= MOD;return t;}if(k == 5){LL t = 2*mu(n,6)%MOD + 6*mu(n,5)%MOD + 5*mu(n,4)%MOD -mu(n,2)%MOD;t %= MOD;t += MOD;t %= MOD;t *= 83333334;t %= MOD;return t;} }LL sum(LL n,int k) {LL ans = 0;LL T = (LL)sqrt(1.0*n);for(int i=1; i<=T; i++){LL t = (n/i) % MOD;LL a = t * t % MOD;LL b = mu(i,k) * a % MOD;LL c = i * i % MOD;LL L = n/(i+1) + 1;LL R = n/i;LL d = calc(R,k) - calc(L-1,k);d %= MOD;d += MOD;d %= MOD;c = c * d % MOD;ans += b + c;ans %= MOD;}if(T*T == n)ans -= mu(T,k+2);ans %= MOD;ans += MOD;ans %= MOD;return ans; }LL dfs(LL n,int k) {if(n < N && dp[n]) return dp[n];if(n == 1) return 1;LL ans = sum(n,k);LL tmp = 0;for(LL i=1; i*i<=n; i++){if(i*i == n){tmp %= MOD;tmp += dfs(i,k);tmp %= MOD;}else{tmp %= MOD;tmp += dfs(i,k);tmp %= MOD;if(i == 1) continue;tmp += dfs(n/i,k);tmp %= MOD;}}if(n < N)dp[n] = ((ans-tmp)%MOD + MOD) % MOD;return ((ans-tmp)%MOD + MOD) % MOD; }int main() {LL n,k;memset(dp,0,sizeof(dp));scanf("%lld%lld",&n,&k);printf("%lld\n",dfs(n,k));return 0; }


?

?

?

?

總結

以上是生活随笔為你收集整理的又见莫比乌斯反演的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 中文一区视频 | 欧美日韩国产成人精品 | 国产suv一区二区 | 欧美日韩亚洲一区 | 国产精品乱码一区二三区小蝌蚪 | 在线麻豆视频 | 日本在线视频免费 | 国产秋霞 | 国产亚洲欧美日韩高清 | av制服丝袜 | 日韩经典一区二区三区 | 亚洲天堂一区二区在线观看 | 男人av的天堂 | 久久精品国产亚洲AV高清综合 | 欧美在线免费观看视频 | 一个综合色 | 91麻豆精品一区二区三区 | 插我舔内射18免费视频 | 一级黄色片欧美 | 国产毛片av | 欧美性生活免费视频 | 亚洲欧美日韩在线 | 国产亚洲欧美在线视频 | 天堂аⅴ在线最新版在线 | 久青草影视 | 麻豆高清 | 日本a v网站 | 国产a一级片 | 小泽玛利亚一区二区三区 | 奇米网7777 | 亚洲图片综合区 | 精品无码久久久久成人漫画 | 围产精品久久久久久久 | 亚洲视频在线观看一区二区三区 | 肉色超薄丝袜脚交一区二区 | ,午夜性刺激免费看视频 | 91久久久久久久久久久久久 | 国产尤物在线 | 91av手机在线 | 91高跟黑色丝袜呻吟在线观看 | 青青草华人在线视频 | 中文字幕永久免费 | 草草在线视频 | 国产激情a | 亚洲第一黄 | 国产精品一区2区 | 98超碰在线| 91久久久久久久 | 日日操夜夜摸 | 中文幕无线码中文字夫妻 | 亚洲国产无线乱码在线观看 | 一区二区三区在线播放 | 欧美国产一区二区 | 色播五月综合 | 无码人妻精品丰满熟人区 | 久久久久亚洲精品中文字幕 | 91视频这里只有精品 | 免费成人高清 | 毛片基地视频 | 亚洲综合久久av | 男人用嘴添女人下身免费视频 | 久操色| 成年人在线观看视频 | 亚洲高清在线观看视频 | 久久影视大全 | 日韩一级在线播放 | 免费在线观看一区二区三区 | 熟女少妇一区二区三区 | 国产亚洲精品网站 | 免费成人黄色网址 | 69视频在线观看 | 日韩视频在线观看一区二区 | 色图自拍| 玖玖精品国产 | 欧美打屁股| 亚洲人成一区 | 亚洲av无一区二区三区怡春院 | 免费视频一二三区 | 人操人爽| 干爹你真棒插曲免费 | 欧美性一区二区三区 | 一区二区三区四区五区av | 午夜特级毛片 | 欧美韩日国产 | 一区二区三区偷拍 | 久久久.com | 国产裸体永久免费视频网站 | 少妇高潮大叫好爽喷水 | 中文字幕区| 一级黄色免费大片 | 内射合集对白在线 | 美女扒开粉嫩的尿囗给男生桶 | 69精品一区二区三区 | 色多多网站 | 中文字幕av网站 | 97免费人妻无码视频 | 欧美日韩国产电影 | 亚洲三级免费观看 | 萌白酱喷水视频 |