【BZOJ4805】欧拉函数求和(杜教筛)
【BZOJ4805】欧拉函数求和(杜教筛)
题面
题解
好久没写过了
正好看见了顺手切一下
令$$S(n)=\sum_{i=1}^n\varphi(i)$$
设存在的某个积性函数\(g(x)\)
\]
\]
\]
\]
\]
\]
拿出杜教筛的套路柿子
\]
我们知道\((\varphi*1)=x\)
\]
\]
预处理\(10^7\)然后杜教筛美滋滋
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MAX 10000000
inline int read()
{
    RG int x=0,t=1;RG char ch=getchar();
    while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
    if(ch=='-')t=-1,ch=getchar();
    while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
    return x*t;
}
int pri[MAX+10],tot;
bool zs[MAX+10];
ll phi[MAX+10];
void pre()
{
	zs[1]=true;phi[1]=1;
	for(int i=2;i<=MAX;++i)
	{
		if(!zs[i])pri[++tot]=i,phi[i]=i-1;
		for(int j=1;j<=tot&&pri[j]*i<=MAX;++j)
		{
			zs[i*pri[j]]=true;
			if(i%pri[j])phi[i*pri[j]]=phi[i]*phi[pri[j]];
			else{phi[i*pri[j]]=phi[i]*pri[j];break;}
		}
	}
	for(int i=1;i<=MAX;++i)phi[i]+=phi[i-1];
}
map<ll,ll> M;
ll Solve(ll x)
{
	if(x<=MAX)return phi[x];
	if(M[x])return M[x];
	ll ret=0;
	for(ll i=2,j;i<=x;i=j+1)
	{
		j=x/(x/i);
		ret+=(j-i+1)*Solve(x/i);
	}
	return M[x]=x*(x+1)/2-ret;
}
int main()
{
	pre();
	int n=read();
	printf("%lld\n",Solve(n));
	return 0;
}
												
											【BZOJ4805】欧拉函数求和(杜教筛)的更多相关文章
- BZOJ4805: 欧拉函数求和(杜教筛)
		
4805: 欧拉函数求和 Time Limit: 15 Sec Memory Limit: 256 MBSubmit: 614 Solved: 342[Submit][Status][Discus ...
 - 【bzoj3944/bzoj4805】Sum/欧拉函数求和  杜教筛
		
bzoj3944 题目描述 输入 一共T+1行 第1行为数据组数T(T<=10) 第2~T+1行每行一个非负整数N,代表一组询问 输出 一共T行,每行两个用空格分隔的数ans1,ans2 样例输 ...
 - BZOJ 4805: 欧拉函数求和 杜教筛
		
https://www.lydsy.com/JudgeOnline/problem.php?id=4805 给出一个数字N,求sigma(phi(i)),1<=i<=N https://b ...
 - 【BZOJ3944/4805】Sum/欧拉函数求和 杜教筛
		
[BZOJ3944]Sum Description Input 一共T+1行 第1行为数据组数T(T<=10) 第2~T+1行每行一个非负整数N,代表一组询问 Output 一共T行,每行两个用 ...
 - LOJ6686 Stupid GCD(数论,欧拉函数,杜教筛)
		
做题重心转移到 LOJ 了. 至于为什么,如果你知道“……”的密码,就去看吧. LOJ 上用户自创题大多数都不可做,今天看到个可做题(而且还是个水题),就来做了一发. 明显枚举立方根.(以下令 $m= ...
 - 51 NOD 1239 欧拉函数之和(杜教筛)
		
1239 欧拉函数之和 基准时间限制:3 秒 空间限制:131072 KB 分值: 320 难度:7级算法题 收藏 关注 对正整数n,欧拉函数是小于或等于n的数中与n互质的数的数目.此函数以其首名研究 ...
 - 【51nod】1239 欧拉函数之和 杜教筛
		
[题意]给定n,求Σφ(i),n<=10^10. [算法]杜教筛 [题解] 定义$s(n)=\sum_{i=1}^{n}\varphi(i)$ 杜教筛$\sum_{i=1}^{n}(\varph ...
 - 51nod1244 欧拉函数之和 杜教筛
		
和上一题差不多,一个是μ*I=e,一个是φ*I=Id 稍改就得到了这题的代码 (我会告诉你我一开始逆元算错了吗) #include <bits/stdc++.h> #define MAX ...
 - [51Nod 1244] - 莫比乌斯函数之和  &  [51Nod 1239] - 欧拉函数之和 (杜教筛板题)
		
[51Nod 1244] - 莫比乌斯函数之和 求∑i=1Nμ(i)\sum_{i=1}^Nμ(i)∑i=1Nμ(i) 开推 ∑d∣nμ(d)=[n==1]\sum_{d|n}\mu(d)=[n== ...
 - Bzoj4805: 欧拉函数求和
		
好久没写杜教筛了 练练手AC量刷起 # include <bits/stdc++.h> # define RG register # define IL inline # define F ...
 
随机推荐
- react-native WebView 返回处理 (非回调方法可解决)
			
1.前言 项目中有些页面内容是变更比较频繁的,这些页面我们会考虑用网页来解决. 在RN项目中提供一个公用的Web页,如果是网页内容,就跳转到这个界面展示. 此时会有一个问题是,网页会有一级页面,二级页 ...
 - struct stat结构体简介
			
在使用这个结构体和方法时,需要引入: <sys/types.h> <sys/stat.h> struct stat这个结构体是用来描述一个linux系统文件系统中的文件属性的结 ...
 - 百度编辑器Ueditor增加字体的修改方法
			
http://www.jb51.net/article/109896.htm Ueditor本身自带11种字体 使用过程中这11种字体往往不能满足我们的需求,现在我要添加"仿宋" ...
 - MySQL备份常用命令总结
			
MySQL备份常用命令总结 1.数据库和数据全部备份 mysqldump -uroot -pPassword -hlocalhost databasename > test.sqlmysqldu ...
 - SQL SERVER FOR LINUX初体验
			
今天得空,就在Ubuntu17.04上安装了SQL SERVER 2017体验下,总体来说还是不错的. 在Ubuntu上安装SQL SERVER 2017还是比较方便的,只需几条命令即可: curl ...
 - Ansible playbook循环实践总结<一>
			
1.标准Loops 标准loops可以直接减少task的次数,如下: [root@zero01 playbook]# vi loops.yaml --- - hosts: all gather_fac ...
 - header 头各种类型文件下载
			
function down_file($url,$type='application/zip'){ header("Cache-Control: public"); ...
 - Linux常用命令详解(一)  -- 处理目录常用命令
			
ls:列出目录 作用:查看linux文件夹包含的文件以及其权限(包括目录.文件夹.文件权限)和目录信息等 命令格式:ls [选项] [文件或目录] 选项或参数: ...
 - 如何通过以太坊智能合约来进行众筹(ICO)
			
前面我们有两遍文章写了如何发行代币,今天我们讲一下如何使用代币来公开募资,即编写一个募资合约. 写在前面 本文所讲的代币是使用以太坊智能合约创建,阅读本文前,你应该对以太坊.智能合约有所了解,如果你还 ...
 - Jenkins系列——使用checkstyle进行代码规范检查
			
1.目标 通过jenkins使用checkstyle对代码进行规范检查并生成html报告. 构建采用shell. 2.环境 checkstyle5.7(如果是Linux版本选用tar.gz格式) ap ...