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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

2019 Multi-University Training Contest 1 - 1011 - Function - 数论

發(fā)布時(shí)間:2024/4/17 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2019 Multi-University Training Contest 1 - 1011 - Function - 数论 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

http://acm.hdu.edu.cn/showproblem.php?pid=6588

新學(xué)到了一個(gè)求n以內(nèi)與m的gcd的和的快速求法。也就是下面的S1。


①求:

$ \sum\limits_{i=1}^{n}gcd(m,i) $

②枚舉d:

$ \sum\limits_{d|m} d \sum\limits_{i=1}^{n} [gcd(m,i)==d] $

③顯然:

$ \sum\limits_{d|m} d \sum\limits_{i=1}^{\lfloor\frac{n}ozvdkddzhkzd\rfloor} [gcd(\frac{m}ozvdkddzhkzd,i)==1] $

到這一步已經(jīng)可以遞歸求了,琪琪說是 \(O(n^{\frac{3}{4}})\) ,不過題解可以繼續(xù)往下。

④為了方便直接考慮 $ \sum\limits_{i=1}^{n} [gcd(m,i)==1] $ ,反演(大概):

$ \sum\limits_{i=1}^{n} \sum\limits_{d|gcd(m,i)} \mu(d) $

⑤交換一下順序,枚舉d,很顯然n以內(nèi)的d的倍數(shù)都會(huì)貢獻(xiàn)一個(gè)mu(d):

$ \sum\limits_{d|m} \mu(d) \lfloor\frac{n}ozvdkddzhkzd\rfloor $


下面的是根據(jù)題解的實(shí)現(xiàn),不過是__int64的版本。

#include<bits/stdc++.h> using namespace std; typedef long long ll; typedef __int64 lll;const int mod = 998244353; const int MAXN = 10000000;int phi[MAXN + 1]; int pri[MAXN + 1], pritop; bool notpri[MAXN + 1];void sieve() {int n = MAXN;pri[1] = phi[1] = 1;for(int i = 2; i <= n; i++) {if(!pri[i])pri[++pritop] = i, phi[i] = i - 1;for(int j = 1, tmp; j <= pritop && (tmp = i * pri[j]) <= n; j++) {pri[tmp] = 1;if(i % pri[j])phi[tmp] = phi[i] * phi[pri[j]];else {phi[tmp] = phi[i] * pri[j];break;}}} }ll S1(lll n, int m) {//sigma gcd(i,m) [1,n]ll res = 0;for(int T = 1; T * T <= m; ++T) {if(!(m % T)) {res += (n / T) * phi[T];if(T * T != m) {res += (n / (m / T)) * phi[(m / T)];}}}res %= mod;return res; }ll qpow(ll x, int n) {ll res = 1;while(n) {if(n & 1)res = res * x % mod;x = x * x % mod;n >>= 1;}return res; }const int inv2 = qpow(2ll, mod - 2); const int inv6 = qpow(6ll, mod - 2);ll sigma1(ll x) {return x * (x + 1ll) % mod * inv2 % mod; }ll sigma2(ll x) {return x * (x + 1ll) % mod * (2ll * x + 1ll) % mod * inv6 % mod; }ll S2_1(int r, int T) {int c = r / T;ll res = 0;res += 3ll * T * sigma2(c);res += 3ll * sigma1(c);res += c;res %= mod;return res; }ll S2(int r) {ll res = 0;for(int T = 1; T <= r; ++T) {res += 1ll * phi[T] * S2_1(r, T) % mod;}res %= mod;return res; }ll S0(lll n) {lll i, i3;for(i = 1;; ++i) {lll tmp = i * i * i;if(tmp > n) {--i;break;} elsei3 = tmp;}ll res = 0;res += S1(n, i) - S1(i3 - 1, i);res += S2(i - 1);res = (res % mod + mod) % mod;return res; }inline lll read() {lll x = 0;char c;do {c = getchar();} while(c < '0' || c > '9');do {x = (x << 3) + (x << 1) + c - '0';c = getchar();} while(c >= '0' && c <= '9');return x; }int main() { #ifdef Yinkufreopen("Yinku.in", "r", stdin); #endif // Yinkusieve();int T;cin >> T;lll n;while(T--) {n = read();cout << S0(n) << endl;} }

其實(shí)具體的思路還是要先分成兩部分來算,但是我當(dāng)時(shí)不會(huì)計(jì)算這個(gè)S1導(dǎo)致T了。其實(shí)計(jì)算S2的時(shí)候在整數(shù)較大的時(shí)候發(fā)生了溢出。也就是c*c的位置。所以說以后非數(shù)組的值一律開ll就對了。

#include<bits/stdc++.h> using namespace std; typedef long long ll; typedef __int128 lll;const int mod = 998244353; const int MAXN = 10000000;int pk[MAXN + 1]; int sum1[MAXN + 1]; int phi[MAXN + 1]; int pri[MAXN + 1], pritop; bool notpri[MAXN + 1];void sieve() {int n = MAXN;pri[1] = pk[1] = sum1[1] = phi[1] = 1;for(int i = 2; i <= n; i++) {if(!pri[i])pri[++pritop] = i, phi[i] = i - 1, pk[i] = i, sum1[i] = 2 * i - 1;for(int j = 1, p, tmp; j <= pritop && (p = pri[j]) && (tmp = i * p) <= n; j++) {pri[tmp] = 1;if(i % p) {pk[tmp] = pk[p];sum1[tmp] = 1ll * sum1[i] * sum1[p] % mod;phi[tmp] = phi[i] * phi[p];} else {pk[tmp] = pk[i] * p;if(pk[tmp] == tmp) {sum1[tmp] = (1ll * sum1[i] * p % mod + (tmp - tmp / p)) % mod;} else {sum1[tmp] = 1ll * sum1[pk[tmp]] * sum1[tmp / pk[tmp]] % mod;}phi[tmp] = phi[i] * p;break;}}} }int sum2[MAXN + 1];ll qpow(ll x, int n) {ll res = 1;while(n) {if(n & 1)res = res * x % mod;x = x * x % mod;n >>= 1;}return res; }void init() {for(int c = 1, c1 = 2, c2 = 7, f1 = 1; c <= MAXN;) {sum2[c] = ((1ll * c2 - f1 + mod) % mod * sum1[c] % mod * qpow(c, mod - 2) % mod + c + sum2[c - 1]) % mod;++c, ++c1, f1 = c2 + 1;c2 = (1ll * c1 * c1 % mod * c1 % mod - 1 + mod) % mod;} }ll S1(lll n, int m) {//sigma gcd(i,m) [1,n]ll res = 0;for(int T = 1; T * T <= m; ++T) {if(!(m % T)) {res += (n / T) * phi[T];if(T * T != m) {res += (n / (m / T)) * phi[(m / T)];}}}res %= mod;return res; }ll S0(lll n) {lll i, i3;for(i = 1;; ++i) {lll tmp = i * i * i;if(tmp > n) {--i;break;} elsei3 = tmp;}ll res = 0;res += S1(n, i) - S1(i3 - 1, i);res += sum2[i - 1];res = (res % mod + mod) % mod;return res; }inline lll read() {lll x = 0;char c;do {c = getchar();} while(c < '0' || c > '9');do {x = (x << 3) + (x << 1) + c - '0';c = getchar();} while(c >= '0' && c <= '9');return x; }int main() { #ifdef Yinkufreopen("Yinku.in", "r", stdin); #endif // Yinkusieve();init();int T;cin >> T;lll n;while(T--) {n = read();cout << S0(n) << endl;} }

轉(zhuǎn)載于:https://www.cnblogs.com/Yinku/p/11229435.html

總結(jié)

以上是生活随笔為你收集整理的2019 Multi-University Training Contest 1 - 1011 - Function - 数论的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 超碰伊人网 | 国产乱淫av麻豆国产免费 | 欧美不卡一二三 | 我爱52av| 欧美××××黑人××性爽 | 国产精品久久久午夜夜伦鲁鲁 | 在线看的av网站 | 潘金莲性xxxxhd| jzzjzz日本丰满成熟少妇 | 色哟哟在线免费观看 | 草草影院一区二区三区 | 青青自拍视频 | 波多野结衣电影在线播放 | 国产人免费人成免费视频 | 亚洲欧美日韩激情 | 日韩激情综合网 | 亚洲第一成年人网站 | 蜜桃av网站 | 秋霞中文字幕 | 精品国产二区三区 | 日日夜夜精品免费视频 | 国产精品一区二区免费在线观看 | 97超碰碰 | 成人欧美精品一区二区 | 99国产超薄肉色丝袜交足 | 色亚洲视频 | 射久久 | 成人精品在线观看视频 | 麻豆国产91在线播放 | 激情av小说 | 免费毛片网站在线观看 | 欧美日韩精品在线视频 | 中文字幕乱码亚洲无线三区 | 草色噜噜噜av在线观看香蕉 | 色奇米| 香港三级韩国三级日本三级 | 男人的天堂视频网站 | 日韩三区四区 | 久久久亚洲国产 | 久久久精品一区二区 | 久久传媒 | www.伊人| 国产一区二区三区视频 | 成人av地址 | 99精品久久久久久久 | 成人毛片100免费观看 | 动漫美女被吸奶 | 日本a∨视频 | 久草老司机 | 在线观看的黄网 | 欧美专区第一页 | 99久免费精品视频在线观78 | 999久久久国产精品 韩国精品一区二区 | 亚洲精品成人无码熟妇在线 | 黄色片亚洲 | 一级理论片 | 中文在线免费看视频 | 操极品| 先锋影音av资源网 | 亚洲精品国产精华液 | 伊人久久中文字幕 | 欧美1区2区| 美女尿尿网站 | 国产一区精品视频 | 亚洲精品视频播放 | 国产精品日本一区二区在线播放 | 9人人澡人人爽人人精品 | 超碰网站在线 | 综合欧美亚洲 | 国语av | 亚洲天堂久久新 | 亚洲欧美一区二区三区久久 | 欧美熟妇7777一区二区 | 日本欧美一区二区三区 | 五月婷婷亚洲 | 亚洲国产精品久久人人爱 | 欧美日免费 | 老熟妇仑乱视频一区二区 | 亚洲精品一区二区在线 | xx视频在线| 911久久| 精品国产乱码久久久久久婷婷 | 人人妻人人做人人爽 | 国产精品国产三级国产专区52 | 黄色.com| 欧美成人黑人猛交 | 成人福利在线播放 | 免费一级片视频 | 女生扒开尿口 | 久久亚洲激情 | 中文字幕亚洲无线码在线一区 | 40到50岁中老年妇女毛片 | 久久蜜桃av | 国产一区在线看 | 黄色永久网站 | 久久美女av | 在线观看的av网站 | 国产日韩欧美一区二区东京热 | 18岁成年人网站 |