Description

去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了。

在整理以前的试题时,发现了这样一道题目“求Sigma(f(i)),其中1<=i<=N”,其中 表示i的约数个数。他现在长大了,题目也变难了。
求如下表达式的值:
 
其中 表示ij的约数个数。
他发现答案有点大,只需要输出模1000000007的值。

Input

第一行一个整数n。

Output

一行一个整数ans,表示答案模1000000007的值。

Sample Input

2

Sample Output

8

HINT

对于100%的数据n <= 10^9。

Solution

因为直接用编辑器打公式比较麻烦且丑,就用markdown截图完传图片了= =b。

Code

 #include <cstdio>
#include <cmath> #define R register
const int mod = 1e9 + ;
#define maxn 1500010
int miu[maxn], smiu[maxn], pr[maxn / ], prcnt, lim, N;
bool vis[maxn];
int hash[maxn];
bool vihash[];
int Miu(R int n)
{
if (n <= lim) return smiu[n];
if (vihash[N / n]) return hash[N / n]; vihash[N / n] = ;
R int ret = ;
for (R int i = , j; i <= n; i = j + )
{
j = n / (n / i);
(ret += mod - 1ll * (j - i + ) * Miu(n / i) % mod) %= mod;
}
return hash[N / n] = ret;
}
inline int sumf(R int n)
{
R int ret = ;
for (R int i = , j; i <= n; i = j + )
{
j = n / (n / i);
ret = (ret + 1ll * (j - i + ) * (n / i)) % mod;
}
return ret;
}
int main()
{
scanf("%d", &N);
lim = (int) pow(N * 1.0, 0.666);
// printf("%d\n", lim);
miu[] = smiu[] = ;
for (R int i = ; i <= lim; ++i)
{
if (!vis[i]) pr[++prcnt] = i, miu[i] = -;
smiu[i] = (smiu[i - ] + miu[i]) % mod;
for (R int j = ; j <= prcnt && 1ll * i * pr[j] <= lim; ++j)
{
vis[i * pr[j]] = ;
if (i % pr[j]) miu[i * pr[j]] = -miu[i];
else
{
miu[i * pr[j]] = ;
break;
}
}
}
R int ans = , last = ;
for (R int i = , j; i <= N; i = j + )
{
j = N / (N / i);
R int Ph = Miu(j);
R int fs = sumf(N / i);
// printf("l = %d r = %d %d %d\n", i, j, Ph, fs);
ans = (ans + 1ll * (Ph - last + mod) * fs % mod * fs) % mod;
last = Ph;
}
// printf("%d\n", last);
printf("%d\n", ans % mod);
return ;
}

【BZOJ4176】 Lucas的数论的更多相关文章

  1. BZOJ4176: Lucas的数论

    Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目“求Sigma(f(i)),其中1<=i<=N”,其 ...

  2. BZOJ4176 Lucas的数论 【莫比乌斯反演 + 杜教筛】

    题目 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目"求Sigma(f(i)),其中1<=i<=N", ...

  3. bzoj4176. Lucas的数论 杜教筛

    题意:求\(\sum_{i=1}^n\sum_{j=1}^nd(ij),d是约数个数函数\) 题解:首先有一个结论\(d(ij)=\sum_{x|i}\sum_{y|j}[(i,j)==1]\) 那么 ...

  4. 【BZOJ4176】Lucas的数论 莫比乌斯反演

    [BZOJ4176]Lucas的数论 Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目“求Sigma(f(i)) ...

  5. Lucas的数论题解

    Lucas的数论 reference 题目在这里> < Pre 数论分块 默认向下取整时. 形如\(\sum\limits_{i=1}^n f\left( \frac{n}{i}\righ ...

  6. Lucas的数论(math)

    Lucas的数论(math) 题目描述 去年的今日,Lucas仍然是一个热爱数学的孩子.(现在已经变成业界毒瘤了> <) 在整理以前的试题时,他发现了这么一道题目:求\(\sum\limi ...

  7. BZOJ 4176: Lucas的数论 [杜教筛]

    4176: Lucas的数论 题意:求\(\sum_{i=1}^n \sum_{j=1}^n \sigma_0(ij)\) \(n \le 10^9\) 代入\(\sigma_0(nm)=\sum_{ ...

  8. bzoj 4176: Lucas的数论 -- 杜教筛,莫比乌斯反演

    4176: Lucas的数论 Time Limit: 30 Sec  Memory Limit: 256 MB Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么 ...

  9. bzoj 4176 Lucas的数论

    bzoj 4176 Lucas的数论 和约数个数和那题差不多.只不过那个题是多组询问,这题只询问一次,并且 \(n\) 开到了 \(10^9\). \[ \begin{align*} \sum_{i= ...

  10. Mobius反演与积性函数前缀和演学习笔记 BZOJ 4176 Lucas的数论 SDOI 2015 约数个数和

    下文中所有讨论都在数论函数范围内开展. 数论函数指的是定义域为正整数域, 且值域为复数域的函数. 数论意义下的和式处理技巧 因子 \[ \sum_{d | n} a_d = \sum_{d | n} ...

随机推荐

  1. Spring 容器中 Bean 的生命周期

    Spring 容器中 Bean 的生命周期 1. init-method 和 destory-method 方法 Spring 初始化 bean 或销毁 bean 时,有时需要作一些处理工作,因此 s ...

  2. 怎样理解String的slice(), subString(), substr()三个方法

    String.prototype.slice() 是js字符串的切片工具方法, 用于对字符串做'裁剪'操作, 不改变原字符串. 'helloworld'.slice(0,5); // 'hello'; ...

  3. mybatis 主键自增异常

     org.springframework.jdbc.UncategorizedSQLException: Error getting generated key or setting result t ...

  4. 【原创】大叔经验分享(74)nginx对静态文件加速

    通过location配置 location ~ \.html$ { add_header 'Cache-Control' 'no-cache'; } location ~ \.(js|css|gif| ...

  5. warning C4819 的解决方法

    编译VC++程序的时候出现如下提示警告: warning C4819: The file contains a character that cannot be represented in the ...

  6. HBASE学习笔记(一)

    一.数据库OLAP和OLTP简单的介绍比较 1.OLTP:on-line transaction processing在线事务处理,应用在传统关系型数据库比较多,执行日常基本的事务处理,比如数据库记录 ...

  7. java字符串大小写转换

    String test="SHA34cccddee";    System.out.println(test.toUpperCase());//小写转大写 String test= ...

  8. 【Swift后台】目录

    背景介绍 环境安装

  9. Linux中的sudoer详解

    目录 Linux中的sudo详解 一.引言 二.格式 三./etc/sudoers文件 四.sudoers文件讲解 五.其他 Linux中的sudo详解 一.引言 Liunx用户只有两类: 管理员用户 ...

  10. centos 7 安装 LNMPC cacti 1.2.7 监控

    先上图,后续更新