UVA12493 - Stars(求1-N与N互质的个数)欧拉函数
Sample Input
3
4
5
18
36
360
2147483647
Sample Output
1
1
2
3
6
48
1073741823
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=3937
题目大意:圆上有N个点把圆分成N等分,求隔同样的点能一笔画全然部点的方法;
思考:要一笔画出,那么(N。K)必然没有在中间相交,而仅仅能在起始位置。(把K当作是K等分),所以K就是和N互质的个数,又由于K=1和K=N-1,结果是一样的。所以最后的结果除以2;
思路:求1-N 互质的数的个数。
能够用到欧拉函数的 φ函数
转载请注明出处:寻找&星空の孩子
φ函数的值 通式:φ(x)=x(1-1/p1)(1-1/ lemmaId=404832&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">p2 lemmaId=278142&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">质因数 lemmaId=256611" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">互质
p2……pn为x的全部
(注意:每种质因数仅仅一个。比方12=2*2*3那么φ(12)=12*(1-1/2)*(1-1/3)=4
若n是 lemmaId=67850&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">质数 lemmaId=442888&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">k-1
设n为正整数,以 φ(n)表示不超过n且与n互
素的正整数的个数。称为n的欧拉函数值,这里函数
φ:N→N,n→φ(n)称为欧拉函数。
欧拉函数是 lemmaId=775751" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">积性函数 lemmaId=104694&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">mn
特殊性质:当n为奇数时,φ(2n)=φ(n), 证明与上述类似。 转载自:欧拉函数
#include<stdio.h>
#define LL long long
//UVA用
LL fun(LL m)
{
LL res=m;
for(LL i=2;i*i<=m;i++)
{
if(m%i==0)
{
res=(res*(i-1))/i;
// printf("i=%I64d,res=%I64d\n",i,res);
while(m%i==0)
{
m/=i;
}
}
}
if(m>1) res=(res*(m-1))/m;
return res;
}
int main()
{
LL n;
while(scanf("%lld",&n)!=EOF)
{
printf("%lld\n",fun(n)/2);
}
return 0;
}
或者
#include<stdio.h>
#include<math.h>
int eular(int n)
{
int ret=1,i;
for(i=2; i<=sqrt(n); i++)
{
if(n%i==0)
{
n=n/i;
ret*=(i-1);
while(n%i==0)
{
// printf("n=%d\ti=%d\tret=%d\n",n,i,ret);
n/=i;
ret*=i;//这样考虑更优
}
}
} if(n>1)
ret*=(n-1);
return ret;
}
int main()
{
int t,a,j;
while(scanf("%d",&a)!=EOF)
{
printf("%d\n",eular(a)/2);
}
return 0;
}
UVA12493 - Stars(求1-N与N互质的个数)欧拉函数的更多相关文章
- UVA 12493 Stars (欧拉函数--求1~n与n互质的个数)
pid=26358">https://uva.onlinejudge.org/index.phpoption=com_onlinejudge&Itemid=8&cate ...
- 欧拉函数求在1-n-1与n互质的个数
long long phi(long long x) { long long res=x,a=x,i; ;i*i<=a;i++) { ) { res=res/i*(i-); ) a=a/i; } ...
- 欧拉函数(小于或等于n的数中与n互质的数的数目)&& 欧拉函数线性筛法
[欧拉函数] 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命名,它又称为Euler’s totient function.φ函数.欧拉商数等. 例如φ( ...
- hdu-4135 Co-prime---容斥定理经典&&求1-m中与n互质的数目
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4135 题目大意: 求区间[a, b]中与N互质的数目. 解题思路: 首先对n求出所有素因子. 对于区 ...
- (hdu step 7.2.2)GCD Again(欧拉函数的简单应用——求[1,n)中与n不互质的元素的个数)
题目: GCD Again Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU-1695 GCD(求一个区间内与一个数互质的个数)
题意: 给你一个T,是样例的个数,接下来是五个数l1,r1,l2,r2,k 前四个数代表两个区间(l1,r1),(l2,r2)这个题l1=1,l2=1; 取x1属于(1,r1),x2属于(1,r2) ...
- poj3696 快速幂的优化+欧拉函数+gcd的优化+互质
这题满满的黑科技orz 题意:给出L,要求求出最小的全部由8组成的数(eg: 8,88,888,8888,88888,.......),且这个数是L的倍数 sol:全部由8组成的数可以这样表示:((1 ...
- 【poj2478-Farey Sequence】递推求欧拉函数-欧拉函数的几个性质和推论
http://poj.org/problem?id=2478 题意:给定一个数x,求<=x的数的欧拉函数值的和.(x<=10^6) 题解:数据范围比较大,像poj1248一样的做法是不可行 ...
- BZOJ2818: Gcd 欧拉函数求前缀和
给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 如果两个数的x,y最大公约数是z,那么x/z,y/z一定是互质的 然后找到所有的素数,然后用欧拉函数求一 ...
随机推荐
- outline
a标签 两种button按钮 默认带有一个虚线 outline 当他们被单击 和 激活以后 outline和border 很类似 ,但是有不同 1.outline 不能针对特定的边赋值 ,也就 ...
- maven下的sqlserver配置jar包
看了两天的maven,开始把之前做的ssm项目搭建成maven项目,结果在sqlserver的依赖包上受阻,sqlserver需要sqljdbc4.jar包,经过一系列百度教程才得以解决,现在总结一下 ...
- .Net开发小技巧
.NET项目开发中的小技巧 1.不要频繁的创建对象...这个损失是巨大的...new太多了,后果比较严重. 2.打开数据库后要及时的关闭连接,如果你不能做到一个open后跟一个close,那也没关系, ...
- C#中抽象类和接口的区别3
一.普通类和抽象类之间的异同 1.都可以被继承 2.抽象类不能被实例化,只是用来继承的.普通类可以实例化 3.抽象方法只有含方法声明而没有方法体且必须包含在抽象类里面 4.子类继承抽象类必须实现抽象类 ...
- C#模拟登录总结
/// <summary> 登录 /// </summary> /// <param name="url">< ...
- Kotlin(二) 函数定义
1.不带参数,不返回值的函数 fun sum(){} 2.带参数,不带返回值的函数 fun sum(a:Int){} 3.带参数,带返回值的函数 fun sum(a:Int,b:Int) : Int{ ...
- struts2 内容记录
多xml文件配置 在开发过程中我们经常会将每一张表(如:user表)的struts.xml文件分开,便于管理,故需要建立struts_user.xml文件管理请求等.那么需要用到inculde标签. ...
- [转载] 详述三种现代JVM语言--Groovy,Scala和Clojure
转载自http://www.tuicool.com/articles/jYzuAv和http://www.importnew.com/1537.html 在我与Martin Fowler曾经合作呈现的 ...
- [转载] 深入剖析 redis 主从复制
转载自http://www.cnblogs.com/daoluanxiaozi/p/3724299.html 主从概述 redis 支持 master-slave(主从)模式,redis server ...
- [转载] linux中文件描述符fd和文件指针flip的理解
转载自http://www.cnblogs.com/Jezze/archive/2011/12/23/2299861.html 简单归纳:fd只是一个整数,在open时产生.起到一个索引的作用,进程通 ...