@description@

求:

\[\sum_{i=1}^{n}\sum_{j=1}^{n}gcd^k(i, j)\times lcm(i, j)\times [gcd(i, j) \in prime] \mod 10^9 + 7
\]

原题传送门。

@solution@

\[\begin{aligned}
ans &= \sum_{i=1}^{n}\sum_{j=1}^{n}gcd^k(i, j)\times lcm(i, j)\times [gcd(i, j) \in prime] \\
&= \sum_{d=1}^{n}[d \in prime]\times d^{k+1}\sum_{i=1}^{\lfloor \frac{n}{d}\rfloor}\sum_{j=1}^{\lfloor \frac{n}{d}\rfloor}[gcd(i, j) = 1]\times i \times j
\end{aligned}
\]

后面那个是经典问题了。虽然明显可以莫比乌斯反演,不过注意到 i, j 取值范围相同,可以用欧拉函数。

基于结论 \(gcd(i, n) = gcd(n - i, n)\),与 n 互质的数总是成对存在,所以有:

\[\sum_{i=1}^{n}\sum_{j=1}^{n}[gcd(i, j) = 1]\times i \times j = \sum_{i=1}^{n}\phi(i)\times i^2
\]

记 \(S(n) = \sum_{i=1}^{n}\phi(i)\times i^2\),可以用杜教筛求 \(S\)(能不用 min-25 筛就不用)。则:

\[ans = \sum_{d=1}^{n}[d \in prime]\times d^{k+1}\times S(\lfloor \frac{n}{d}\rfloor)
\]

如果对 \(S(\lfloor \frac{n}{d}\rfloor)\) 分块,我们需要求质数的 k + 1 次幂的前缀和。其实就是 min-25 筛的前半部分。

@accepted code@

#include <cstdio>
#include <algorithm>
using namespace std; typedef long long ll; const int MOD = int(1E9) + 7;
const int MAXN = 4650000; inline int add(int x, int y) {return (x + y >= MOD ? x + y - MOD : x + y);}
inline int sub(int x, int y) {return (x - y < 0 ? x - y + MOD : x - y);}
inline int mul(int x, int y) {return 1LL * x * y % MOD;} int pow_mod(int b, int p) {
int ret = 1;
for(int i=p;i;i>>=1,b=mul(b,b))
if( i & 1 ) ret = mul(ret, b);
return ret;
} bool nprm[MAXN + 5];
int prm[MAXN + 5], phi[MAXN + 5], pcnt;
void sieve() {
phi[1] = 1;
for(int i=2;i<=MAXN;i++) {
if( !nprm[i] ) prm[++pcnt] = i, phi[i] = i - 1;
for(int j=1;i*prm[j]<=MAXN;j++) {
nprm[i*prm[j]] = true;
if( i % prm[j] == 0 ) {
phi[i*prm[j]] = phi[i]*prm[j];
break;
}
else phi[i*prm[j]] = phi[i]*phi[prm[j]];
}
}
}
int c[105][105], f[105][105];
void get_coef() {
for(int i=0;i<=102;i++) {
c[i][0] = 1;
for(int j=1;j<=i;j++)
c[i][j] = add(c[i-1][j], c[i-1][j-1]);
}
for(int i=0;i<=101;i++) {
for(int j=0;j<=i+1;j++)
f[i][j] = c[i+1][j];
for(int j=0;j<i;j++) {
for(int k=0;k<=j+1;k++)
f[i][k] = sub(f[i][k], mul(c[i+1][j], f[j][k]));
}
int iv = pow_mod(i + 1, MOD - 2);
for(int j=0;j<=i+1;j++)
f[i][j] = mul(f[i][j], iv);
}
}
int get_sum(int n, int k) {
int ret = 0;
for(int i=k+1;i>=0;i--)
ret = add(mul(ret, n), f[k][i]);
return ret;
}
int sum[MAXN + 5];
void init() {
sieve(), get_coef();
for(int i=1;i<=MAXN;i++)
sum[i] = add(sum[i-1], mul(mul(i, i), phi[i]));
}
ll n; int k;
int id1[MAXN + 5], id2[MAXN + 5], cnt;
int id(ll m) {return (m <= MAXN ? id1[m] : id2[n/m]);}
ll a[MAXN + 5]; int s[MAXN + 5];
void get_id() {
cnt = 0;
for(ll i=1;i<=n;i=(n/(n/i))+1) {
ll p = n / i;
if( p <= MAXN ) id1[p] = (++cnt);
else id2[n/p] = (++cnt);
a[cnt] = p, s[cnt] = -1;
}
}
int phisum(ll m) {
if( m <= MAXN ) return sum[m];
int &ans = s[id(m)];
if( ans != -1 ) return ans;
ans = get_sum(m % MOD, 3);
for(ll i=2;i<=m;i++) {
ll p = m / i, j = m / p;
ans = sub(ans, mul(sub(get_sum(j % MOD, 2), get_sum((i-1) % MOD, 2)), phisum(p)));
i = j;
}
return ans;
}
int dp[MAXN + 5];
void get_dp() {
for(int i=1;i<=cnt;i++) dp[i] = sub(get_sum(a[i] % MOD, k + 1), 1);
int tmp = 0;
for(int i=1;i<=pcnt;i++) {
ll sq = 1LL*prm[i]*prm[i]; int del = pow_mod(prm[i], k + 1);
if( sq > n ) break;
for(int j=1;j<=cnt;j++) {
if( sq > a[j] ) break;
dp[j] = sub(dp[j], mul(del, sub(dp[id(a[j] / prm[i])], tmp)));
}
tmp = add(tmp, del);
}
}
void solve() {
scanf("%lld%d", &n, &k), get_id(), get_dp(); int ans = 0;
for(ll i=1;i<=n;i++) {
ll p = n / i, j = n / p;
ans = add(ans, mul(sub(phisum(j), phisum(i - 1)), dp[id(p)]));
i = j;
}
printf("%d\n", ans);
}
int main() {
init();
int T; scanf("%d", &T);
while( T-- ) solve();
}

@details@

整除分块时所有数都必须取 long long,但是取模要转成 int。注意一下不要出锅。

@hdu - 6607@ Easy Math Problem的更多相关文章

  1. [HDU - 5170GTY's math problem 数的精度类

    题目链接:HDU - 5170GTY's math problem 题目描述 Description GTY is a GodBull who will get an Au in NOI . To h ...

  2. HDU 5572--An Easy Physics Problem(射线和圆的交点)

    An Easy Physics Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  3. 【HDU 5105】Math Problem

    题意 f(x)=|ax3+bx2+cx+d| 求f(x)在L≤x≤R的最大值. 分析 参数有可能是0,注意分类讨论 1.当a=0时 b=0,f为一次函数(c≠0)或者常数函数(c=0),最大值点在区间 ...

  4. ACM 2015年上海区域赛A题 HDU 5572An Easy Physics Problem

    题意: 光滑平面,一个刚性小球,一个固定的刚性圆柱体 ,给定圆柱体圆心坐标,半径 ,小球起点坐标,起始运动方向(向量) ,终点坐标 ,问能否到达终点,小球运动中如果碰到圆柱体会反射. 学到了向量模板, ...

  5. HDU 6182 A Math Problem

    暴力. $k$的$k$次方在$k=15$的时候,达到了最大不爆掉的情况. #include<bits/stdc++.h> using namespace std; long long an ...

  6. HDU 5055 Bob and math problem(结构体)

    主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=5055 Problem Description Recently, Bob has been think ...

  7. HDU 5572 An Easy Physics Problem (计算几何+对称点模板)

    HDU 5572 An Easy Physics Problem (计算几何) 题目链接http://acm.hdu.edu.cn/showproblem.php?pid=5572 Descripti ...

  8. HDU 1757 A Simple Math Problem 【矩阵经典7 构造矩阵递推式】

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1757 A Simple Math Problem Time Limit: 3000/1000 MS (J ...

  9. hdu 5105 Math Problem(数学)

    pid=5105" target="_blank" style="">题目链接:hdu 5105 Math Problem 题目大意:给定a.b ...

随机推荐

  1. python—day01_环境安装

    搭建环境 1.win10_X64,其他Win版本也可以. 2.安装python.()3.PyCharm版本:Professional-2016.2.3. 在Windows上安装Python 首先,根据 ...

  2. F. Pathwalks动态开辟线段树

    题意:n点m边,然后要求走最多的路,走路的时候经过的边权必须是严格递增. 解法1:传统的区间更新 解法2:发现区间更新只是对两个固定的点所延长形成的区间段,所以问题可以退化成单点更新单点查询. 然后动 ...

  3. SPOJ687 Repeats

    本篇是罗穗骞<后缀数组——处理字符串的有力工具>的读书笔记. 知识点: 后缀数组.RMQ 解题思路: 枚举长度 \(L\),然后检查长度为 \(L\) 的子串最多能连续重复几次. 对于给定 ...

  4. HDU2859

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2859 AC思路:(思路来源于kuangbin,甚至做法也跟kuangbin大同小异,所以可以将本文看成 ...

  5. 花6个月写的付费专栏,免费送|仿开源框架从零到一完整实现高性能、可扩展的RPC框架

    作者 渡码,阿里巴巴码农,公众号:渡码 作者,专注大数据开发.数据分析和Python技术. 关注公众号 渡码 回复关键字 manis,可获取电子书.各章节和完整源代码,并且可加入读者群一起交流问题. ...

  6. WordPress 伪静态规则(IIS/Apache/Nginx)

    不少朋友总是询问 WordPress 如何添加伪静态规则,今天倡萌就总结一下 Apache/Nginx 三种环境下的伪静态规则,希望对大家有所帮助. 检测主机是否支持伪静态的方法:在WP后台 > ...

  7. [COCOS2DX-LUA]0-001.利用ClippingNode实现放大镜功能

    用过Iphone的都知道,Iphone在定位光标位置的时候会把内容进行放大,这样我们就能很快的把光标移动到指定的位置.那么在我们的Cocos2dX的游戏中,怎么可以实现这种功能呢.起先我就是想起了Ip ...

  8. 同步锁Lock & 生产者和消费者案例

    显示锁 Lock ①在 Java 5.0 之前,协调共享对象的访问时可以使用的机 制只有 synchronized 和 volatile . Java 5.0 后增加了一些 新的机制,但并不是一种替代 ...

  9. no-strings-attached

    0x01 拿到程序,直接IDA放进去看一下,结果如图: 我们发现main中有四个函数,我们一个一个进去,经过分析之后,发现authenticate();是关键函数,所以,接下来我们进去看看. void ...

  10. css背景图定位和浮动

    网站图标引入:<link rel="shortcut icon" href="ico图标地址"> 背景图片  background-image: u ...