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)(1-1/p3)(1-1/p4)…..(1-1/pn),当中p1,
p2……pn为x的全部

lemmaId=278142&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">质因数。x是不为0的整数。φ(1)=1(唯一和1

lemmaId=256611" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">互质的数(小于等于1)就是1本身)。
(注意:每种质因数仅仅一个。比方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)">质数p的k次幂。φ(n)=p^k-p^(

lemmaId=442888&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">k-1)=(p-1)p^(k-1)。由于除了p的倍数外,其它数都跟n互质。

设n为正整数,以 φ(n)表示不超过n且与n互

素的正整数的个数。称为n的欧拉函数值,这里函数

φ:N→N,n→φ(n)称为欧拉函数。

欧拉函数是

lemmaId=775751" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">积性函数——若m,n互质,φ(

lemmaId=104694&ss_c=ssc.citiao.link" target="_blank" style="text-decoration:none; color:rgb(51,102,204)">mn)=φ(m)φ(n)。

特殊性质:当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互质的个数)欧拉函数的更多相关文章

  1. UVA 12493 Stars (欧拉函数--求1~n与n互质的个数)

    pid=26358">https://uva.onlinejudge.org/index.phpoption=com_onlinejudge&Itemid=8&cate ...

  2. 欧拉函数求在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; } ...

  3. 欧拉函数(小于或等于n的数中与n互质的数的数目)&& 欧拉函数线性筛法

    [欧拉函数] 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命名,它又称为Euler’s totient function.φ函数.欧拉商数等. 例如φ( ...

  4. hdu-4135 Co-prime---容斥定理经典&&求1-m中与n互质的数目

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4135 题目大意: 求区间[a, b]中与N互质的数目. 解题思路: 首先对n求出所有素因子. 对于区 ...

  5. (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 ...

  6. HDU-1695 GCD(求一个区间内与一个数互质的个数)

    题意: 给你一个T,是样例的个数,接下来是五个数l1,r1,l2,r2,k  前四个数代表两个区间(l1,r1),(l2,r2)这个题l1=1,l2=1; 取x1属于(1,r1),x2属于(1,r2) ...

  7. poj3696 快速幂的优化+欧拉函数+gcd的优化+互质

    这题满满的黑科技orz 题意:给出L,要求求出最小的全部由8组成的数(eg: 8,88,888,8888,88888,.......),且这个数是L的倍数 sol:全部由8组成的数可以这样表示:((1 ...

  8. 【poj2478-Farey Sequence】递推求欧拉函数-欧拉函数的几个性质和推论

    http://poj.org/problem?id=2478 题意:给定一个数x,求<=x的数的欧拉函数值的和.(x<=10^6) 题解:数据范围比较大,像poj1248一样的做法是不可行 ...

  9. BZOJ2818: Gcd 欧拉函数求前缀和

    给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 如果两个数的x,y最大公约数是z,那么x/z,y/z一定是互质的 然后找到所有的素数,然后用欧拉函数求一 ...

随机推荐

  1. Java 内存区域划分 备忘录

    最近看了<深入理解虚拟机>的内存分配与管理这部分的内容,这里做一个的总结,以加深我对知识点的理解,如有错误的地方,还望大神们指出,我及时更正:  内存区域划分 首先是下面这幅图: 图 1. ...

  2. Datatable转换为Json

    /// <summary> /// Datatable转换为Json /// </summary> /// <param name="table"&g ...

  3. DIY 温控烙铁

    由于工艺原因,某处要使用200W大功率烙铁(恒温烙铁虽然有那么大功率,但没有那么大的烙铁头),只能选用普通电热丝烙铁(无温控),存在温度过高现象(造成工艺不良,同时因助焊剂+高温造成烙铁头腐蚀),逐渐 ...

  4. C# 控件的缩写

    1 btn Button 2 chk CheckBox 3 ckl CheckedListBox 4 cmb ComboBox 5 dtp DateTimePicker 6 lbl Label 7 l ...

  5. Android 异步消息处理机制前篇(一):深入理解ThreadLocal

    版权声明:本文出自汪磊的博客,转载请务必注明出处. ThreadLocal简介 ThreadLocal是一个线程内部的数据存储类,通过它可以在指定的线程中存储数据,数据存储以后,只有在指定线程中可以获 ...

  6. Python之matplotlib学习(一)

    小试牛刀 在上一节已经安装好matplotlib模块,下面使用几个例子熟悉一下. 对应的一些文档说明: http://matplotlib.org/1.3.1/api/pyplot_summary.h ...

  7. raid卡MegaCli工具使用说明

    一.DELL&IBMMegaCli -AdpAllInfo -aALL —看配置项 #检查raid级别MegaCli -LDInfo -Lall -aALL | grep 'RAID Leve ...

  8. 使用 Rust 构建分布式 Key-Value Store

    欢迎大家前往腾讯云社区,获取更多腾讯海量技术实践干货哦~ 引子 构建一个分布式 Key-Value Store 并不是一件容易的事情,我们需要考虑很多的问题,首先就是我们的系统到底需要提供什么样的功能 ...

  9. bootstrap栅格布局学习历程

    了解一个东西.他叫什么?他由什么组成,能做什么? 现在响应式的网站(在不同分辨率下有不同的布局)很瘦欢迎.优点:1.解决设备之间的差异化展示缺点:a.兼容性代码多,工作量大,加载速度受到影响;b.用户 ...

  10. SSD: Single Shot MultiBoxDetector英文论文翻译

    SSD英文论文翻译 SSD: Single Shot MultiBoxDetector 2017.12.08    摘要:我们提出了一种使用单个深层神经网络检测图像中对象的方法.我们的方法,名为SSD ...