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. 微信公众平台快速开发框架 For Core 2.0 beta –JCSoft.WX.Core 5.2.0 beta发布

    写在前面 最近比较忙,都没有好好维护博客,今天拿个半成品来交代吧. 记不清上次关于微信公众号快速开发框架(简称JCWX)的更新是什么时候了,自从更新到支持.Net Framework 4.0以后基本上 ...

  2. Scrum Meeting Alpha - 7

    Scrum Meeting Alpha - 7 NewTeam 2017/11/1 地点:新主楼F座二楼 任务反馈 团队成员 完成任务 计划任务 安万贺 登录部分的API仍存在问题 完成登陆部分的AP ...

  3. (原创)遗传算法C++实现

    本文没有对遗传算法的原理做过多的解释 基础知识可以参考下面的博客:http://blog.csdn.net/u010451580/article/details/51178225 本实验用到的变异用到 ...

  4. 初生牛犊不怕虎 golang入坑系列

    读前必读,下面所有内容都是来自这里. 放到这里的目的,就是为了比对一下,哪里的读者多.平心而论,同样的Markdown,博客园排版真心X看,怎么瞅怎么X看.(X := '难' || X :='耐' | ...

  5. 使用dropwizard(5)--加入swagger

    前言 Swagger已经成API service的规范了,本处在dropwizard中简单集成Swagger. Demo source https://github.com/Ryan-Miao/l4d ...

  6. mysql数据库常用命令笔记

    连接数据库:mysql -h localhost -u root -p 000000 退出:exit;    \q;    quit; SET foreign_key_checks = 0; 禁用外键 ...

  7. 33.Linux-实现U盘自动挂载(详解)

    1.当我们每次插入u盘后,都会自动创键U盘的设备节点/dev/sda%d 这是因为里面调用了device_create()实现的, busybox的mdev机制就会根据主次设备号等信息,在/dev下创 ...

  8. sqlmap命令

    -u #注入点 -f #指纹判别数据库类型 -b #获取数据库版本信息 -p #指定可测试的参数(?page=1&id=2 -p "page,id") -D "& ...

  9. P1132 数字生成游戏

    题目请见:传送门 以下为题解,直接从洛谷上搬过来的,还专门改了markdown,(汗) 宽搜 with 一些技巧 由于查询量很大,所以要预先处理所有答案 预处理当然是用BFS,并同时进行delete, ...

  10. asp.net web api 构建api帮助文档

    1 概要 创建ASP.NET Web Api 时模板自带Help Pages框架. 2 问题 1)使用VS创建Web Api项目时,模板将Help Pages框架自动集成到其中,使得Web Api项目 ...