GCD - Extreme(欧拉函数变形)
题目链接:https://vjudge.net/problem/UVA-11426
题目大意: 给出整数n∈[2,4000000],求解∑gcd(i,j),其中(i,j)满足1≤i<j≤n.
的确没有想到是欧拉函数,这怎么会想到欧拉函数呢? 又不是要我们求所有gcd为1的个数 那些gcd不为1的怎么办呢? 当时怎么就没想到呢 除过去不就变为1了吗 自己是真的菜。。。
还是要多做题,把思维开阔起来!!!
思路在代码中 直接看代码:
/**
欧拉函数三个性质
是素数的话 欧拉函数值等于它本身-1
如果a是素数 b%a==0 则phi[b*a]=phi[b]*a
如果b%a!=0 则phi[b*a]=phi[b]*phi[a]
*/
#include<iostream>
#include<cstdio>
using namespace std;
typedef long long LL;
const int maxn=4e6+;
LL N;
LL phi[maxn],vis[maxn],p[maxn];//欧拉函数值 是否是素数 存素数
LL f[maxn],ans[maxn];
void Init()//求欧拉函数值
{
phi[]=;
int num=;
for(int i=;i<maxn;i++)
{
if(!vis[i])//是素数
{
p[num++]=i;
phi[i]=i-;//素数的欧拉函数值就等于它的值-1
}
for(int j=;j<num&&p[j]*i<maxn;j++)
{
vis[p[j]*i]=true;//肯定不是素数
if(i%p[j]==)
{
phi[i*p[j]]=p[j]*phi[i];
break;
}
else phi[i*p[j]]=phi[i]*phi[p[j]];
}
} // for(int i=1;i<=10;i++) cout<<i<<":"<<phi[i]<<" ";
return ;
}
/** 假设n等于4
(1,2) (2,3) (3,4)
(1,3) (2,4)
(1,4) 假设f[n]=(1,n)+(2,n)+···(n-1,n)
则 ans=f[2]+f[3]+···+f[n] 所以我们要求的就是f[n] 假设 gcd(1,n) gcd(2,n) ··· gcd(n-1,n)中等于i的有si个
那么gcd(s1,n)=i gcd(s2,n)=i gcd(si,n)=i
则 gcd(s1/i,n/i)=1 gcd(s2/i,n/i)=1 gcd(si/i,n/i)=1
这岂不是转换成了 总个数phi[n/i]的情形了 所以f[n]=i*phi[n/i] */
void solve()//存f[n]
{
phi[]=;
for(int i=;i<maxn;i++)//遍历i的值 同时得到f[n]的部分值
{
for(int j=i;j<maxn;j+=i)//遍历n的值
{
f[j]+=i*phi[j/i];
}
}
for(int i=;i<maxn;i++) ans[i]=ans[i-]+f[i];
return ;
}
int main()
{
Init();
solve();
//while(scanf("%lld",&N)!=EOF)
while(cin>>N)
{
if(N==) break;
cout<<ans[N]<<endl;
//printf("%lld\n",ans[N]);
}
return ;
}
GCD - Extreme(欧拉函数变形)的更多相关文章
- 【BZOJ】2818: Gcd(欧拉函数+质数)
题目 传送门:QWQ 分析 仪仗队 呃,看到题后感觉很像上面的仪仗队. 仪仗队求的是$ gcd(a,b)=1 $ 本题求的是$ gcd(a,b)=m $ 其中m是质数 把 $ gcd(a,b)=1 $ ...
- hdu2588 GCD (欧拉函数)
GCD 题意:输入N,M(2<=N<=1000000000, 1<=M<=N), 设1<=X<=N,求使gcd(X,N)>=M的X的个数. (文末有题) 知 ...
- uva11426 gcd、欧拉函数
题意:给出N,求所有满足i<j<=N的gcd(i,j)之和 这题去年做过一次... 设f(n)=gcd(1,n)+gcd(2,n)+......+gcd(n-1,n),那么answer=S ...
- HDU 1695 GCD (欧拉函数+容斥原理)
GCD Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- HDU 1787 GCD Again(欧拉函数,水题)
GCD Again Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- hdu 4983 Goffi and GCD(欧拉函数)
Problem Description Goffi is doing his math homework and he finds an equality on his text book: gcd( ...
- hdu 1695 GCD(欧拉函数+容斥)
Problem Description Given 5 integers: a, b, c, d, k, you're to find x in a...b, y in c...d that GCD( ...
- HDU 1695 GCD(欧拉函数+容斥原理)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1695 题意:x位于区间[a, b],y位于区间[c, d],求满足GCD(x, y) = k的(x, ...
- GCD(欧拉函数)
GCD Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissio ...
随机推荐
- (转)初试konckout+webapi简单实现增删改查
原文地址:http://www.cnblogs.com/flykai/p/3361064.html 前言 konckout.js本人也是刚刚接触,也是初学,本文的目的是使用ko和asp.net mvc ...
- PLSA的EM推导
本文作为em算法在图模型中的一个应用,推导plsa的em算法. 1 em算法 em算法是解决一类带有隐变量模型的参数估计问题. 1.1 模型的定义 输入样本为,对应的隐变量为.待估计的模型参数为,目标 ...
- switch case 判断是否为按钮、设置属性 Load Foreach 绑定事件
private void button9_Click(object sender, EventArgs e) { foreach (Control CT in this.Controls) {//判断 ...
- SQL Server Profiler (SQl跟踪器)的简单使用
一.工具介绍 在实际开发中,我们的数据库应用系统因为不可避免会存在有大量表,视图,索引,触发器,函数,存储过程,sql语句等,所以会出现一系列问题,有问题不可怕,找对工具很重要.接下来我就介绍一款性能 ...
- 《Think in Java》
chapter 1 对象导论 面向对象程序设计(Object-oriented Programming ,OOP) chapter 2 一切都是对象 字段和方法 若类的某个成员变量是基本数据类型,即是 ...
- golang文件处理函数openfile与linux系统的文件函数的耦合
golang运行最理想的环境是linux系统中,编译速度和执行速度都比较快,本文是关于golang中的文件操作函数 在golang标准库中os包提供了不依赖平台的借口,但是使用的风格是unix风格的. ...
- .NET clickonce修改发布名称等
见图
- 一、pytest的介绍和安装
需要针对一个项目系统开发一套UI自动化测试脚本,自己结合着学习,采用了pytest去实现,这里留下记录. 什么是pytest pytest 是一个非常成熟的全功能的Python测试框架 可以胜任uni ...
- js 自定义属性
html标签中有没有什么自带的属性可以存储成绩的----没有 本身html标签没有这个属性,自己(程序员)添加的,----自定义属性---为了存储一些数据 在html标签中添加的自定义属性,如果 ...
- ansible基本模块-shell
ansible XXX -m shell -a "XXX"