[Ahoi2005]COMMON 约数研究 【欧拉线性筛的应用】

时间:2022-09-07 08:01:47

1968: [Ahoi2005]COMMON 约数研究

Time Limit: 1 Sec  Memory Limit: 64 MB
Submit: 2939  Solved: 2169
[Submit][Status][Discuss]

Description

[Ahoi2005]COMMON 约数研究   【欧拉线性筛的应用】

Input

只有一行一个整数 N(0 < N < 1000000)。

Output

只有一行输出,为整数M,即f(1)到f(N)的累加和。

Sample Input

3

Sample Output

5

题解

我们知道一个数x的约数个数 = (a1 + 1) * (a2 + 1) * (a3 + 1)......(ak + 1)
其中x的质因子分解:x = p1^a1 * p2^a2 * p3^a3 ......pk^ak
现在我们需要算出所有数的约数个数和
直接算?O(n√n)  n <= 1000000肯定超时
考虑线性筛
若i为质数,显然f[i] = 2
若i不为质数,它一定会在线性筛中被它除去最小的一个质因数后的那个数筛去
例如 20 = 2 * 2 * 5,那么在筛到10 = 2 * 5时,我们会用 2 * 10 筛去20
由于比10及10以前的f值已经确定
这个时候f[20] = f[10] + f[10 / 2^1] = (1 + 1) * (1 + 1) + (1 + 1) = 3 * 2
也就是f[i * prime[j]] = f[i] + f[i除去所有prime[j]后的数]
 
UPD2018.1.27:
其实这道题有更快的方法。。。。是我蠢了
∑[N/i]即可
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<bitset>
#define LL long long int
#define REP(i,n) for (int i = 1; i <= (n); i++)
using namespace std;
const int maxn = 1000005,maxm = 100005,INF = 1000000000;
int prime[maxn],primei = 0,n;
LL f[maxn],M = 0;
bitset<maxn> isp;
void cal(){
int t;
isp.set();
f[1] = 1;
for (int i = 2; i <= n; i++){
if (isp[i]) prime[++primei] = i,f[i] = 2;
for (int j = 1; j <= primei && i * prime[j] <= n; j++){
isp[i * prime[j]] = false;
for (t = i; t % prime[j] == 0; t /= prime[j]);
f[i * prime[j]] = f[i] + f[t];
if (i % prime[j] == 0) break;
}
}
REP(i,n) M += f[i];
}
int main()
{
cin >> n;
cal();
cout << M << endl;
return 0;
}
UPD:
#include<iostream>
using namespace std;
int main(){
int n,nxt; cin>>n;
long long int ans = 0;
for (int i = 1; i <= n; i = nxt + 1){
nxt = n / (n / i);
ans += (long long int)n / i * (nxt - i + 1);
}
cout<<ans<<endl;
return 0;
}

  

[Ahoi2005]COMMON 约数研究 【欧拉线性筛的应用】的更多相关文章

  1. BZOJ 1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究

    1968: [Ahoi2005]COMMON 约数研究 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 2032  Solved: 1537[Submit] ...

  2. BZOJ 1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究 水题

    1968: [Ahoi2005]COMMON 约数研究 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...

  3. BZOJ 1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究&lpar;新生必做的水题&rpar;

    1968: [Ahoi2005]COMMON 约数研究 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 2351  Solved: 1797 [Submi ...

  4. bzoj千题计划170:bzoj1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究

    http://www.lydsy.com/JudgeOnline/problem.php?id=1968 换个角度 一个数可以成为几个数的约数 #include<cstdio> #incl ...

  5. &lbrack;POJ1595&rsqb;欧拉线性筛(虽然这道题不需要&period;&period;&period;)

    欧拉线性筛. 对于它的复杂度的计算大概思考了很久. procedure build_prime; var i,j:longint; begin fillchar(vis,sizeof(vis),tru ...

  6. 欧拉函数O&lpar;sqrt&lpar;n&rpar;&rpar;与欧拉线性筛素数O&lpar;n&rpar;总结

    欧拉函数: 对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目. POJ 2407.Relatives-欧拉函数 代码O(sqrt(n)): ll euler(ll n){ ll ans=n; ...

  7. 1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究

    #include<cstdio> #include<iostream> #define M 1000008 using namespace std; long long tot ...

  8. BZOJ1968&colon; &lbrack;Ahoi2005&rsqb;COMMON 约数研究 线性筛

    按照积性函数的定义筛一下这个积性函数即可. #include <cstdio> #include <algorithm> #define N 1000004 #define s ...

  9. BZOJ1968 &lbrack;Ahoi2005&rsqb;COMMON 约数研究 数论

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1968 题意概括 求 ΣF(i)   (1<=i<=n)N<=1000000 F( ...

随机推荐

  1. ios 数据库存储json数据

    NSData *data = [NSJSONSerialization dataWithJSONObject:info.bdata options:NSJSONWritingPrettyPrinted ...

  2. bcb安装控件方法汇总

    1.BCB 菜单: Project->Options->Packages->Add[喝小酒的网摘]http://blog.const.net.cn/a/8496.htm如果是BCB6 ...

  3. C&plus;&plus; Primer的课后规划问题的第八章

    1.写通常需要一个参数(字符串的地址).字符串和打印功能. 只要.假设提供了第二个参数(int种类),而这个参数不0,的次数的函数打印串数量为该功能将被称为(意,字符串的打印次数不等于第二个參数的值. ...

  4. 一步一步重写 CodeIgniter 框架 &lpar;6&rpar; —— 实现在控制器Controller中加载View

    1. 控制器将模型类获得的数据,传递给视图进行显示,所以视图必须负责接收数据,另外重要的一点是当模型和视图分开后,多个模型的数据可以传递给一个视图进行展示,也可以说一个模型的数据在多个不同的视图中进行 ...

  5. linux fork&lpar;&rpar;函数

    C语言编程创建函数fork() 执行解析 | 浏览:1842 | 更新:2013-04-22 15:12 | 标签:c语言 概述 最近在看进程间的通信,看到了fork()函数,虽然以前用过,这次经过思 ...

  6. 增强学习 &vert; AlphaGo背后的秘密

    "敢于尝试,才有突破" 2017年5月27日,当今世界排名第一的中国棋手柯洁与AlphaGo 2.0的三局对战落败.该事件标志着最新的人工智能技术在围棋竞技领域超越了人类智能,借此 ...

  7. 记一次将公司网站http换成https

    看了博客园将近一年了,一直都只是在被动的看,总觉得应该写点什么,但是又不知道该写点什么.今天正好公司要把网站由http换成https,那我就顺便记录一下吧. 由于之前没有弄过,所以就面向百度编程. 首 ...

  8. jQuery——Js与jQuery的相互转换

    $()与jQuery() jQuery中$函数,根据传入参数的不同,进行不同的调用,实现不同的功能.返回的是jQuery对象 jQuery这个js库,除了$之外,还提供了另外一个函数:jQuery j ...

  9. 龙儿经理嘴上经常说的B树

    国内的数据结构教材一般是按照Knuth定义,即“阶”定义为一个节点的子节点数目的最大值. 对于一棵m阶B-tree,每个结点至多可以拥有m个子结点.各结点的关键字和可以拥有的子结点数都有限制 规定m阶 ...

  10. Python实现目录文件的全量和增量备份

    目标: 1.传入3个参数:源文件路径,目标文件路径,md5文件 2.每周一实现全量备份,其余时间增量备份 1.通过传入的路径,获取该路径下面的所有目录和文件(递归) 方法一:使用os.listdir ...