[BZOJ2190&BZOJ2705]欧拉函数应用两例
欧拉函数phi[n]是表示1~n中与n互质的数个数。
可以用公式phi[n]=n*(1-1/p1)*(1-1/p2)*(1-1/p3)...*(1-1/pk)来表示。(p为n的质因子)
求phi[p]的过程:
procedure calc(p:longint;var sum:longint);
var i:longint;
begin
sum:=p;
for i:= to trunc(sqrt(p)) do
if p mod i= then
begin
sum:=sum div i*(i-);
while p mod i= do p:=p div i;
// 保证每次都是质因子
end;
if p<> then sum:=sum div p*(p-);
// 如果p自身是质数的情况
end;
BZOJ2190
直接套用即可,不处理1的情况最后加上3。需要注意的是读进来的方阵大小应该-1。
直接贴代码。
program bzoj2190;
const maxn=;
var n,i,ans:longint;
phi:array[-..maxn]of longint;
procedure calc(p:longint;var sum:longint);
var i:longint;
begin
sum:=p;
for i:= to trunc(sqrt(p)) do
if p mod i= then
begin
sum:=sum div i*(i-);
while p mod i= do p:=p div i;
end;
if p<> then sum:=sum div p*(p-);
end; begin
readln(n);dec(n);
for i:= to n do calc(i,phi[i]);
ans:=;
for i:= to n do inc(ans,phi[i]);
if n<> then writeln(ans*+) else writeln();
end.
BZOJ 2705
刚开始看可能无从下手。但是再看一眼会发现,如果枚举某个数与n的最大公约数,再求出这样的数有多少的话可能就有方法处理了。
我们来思考有多少个数与n的最大公约数是x,不难想出,当这个数/x,n/x的时候两数互质。也就是其个数=phi[n/x]!
所以只需要枚举所有的最大公约数(枚举到sqrt(n))即可。
需要注意的是如果n正好是完全平方数,sqrt(n)会被计算两次。于是特判。
另外这道题给我们一点启发:sigma(phi[n/i])(n mod i=0)=n!
虽然目前还没有发现有哪里可以应用,但是式子非常优美。。>_<
program bzoj2705;
var i:longint;
ans,n:int64; function phi(p:int64):int64;
var i:longint;
ans:int64;
begin
ans:=p;
for i:= to trunc(sqrt(p)) do if p mod i= then
begin
ans:=ans*(i-) div i;
while p mod i= do p:=p div i;
end;
if p<> then ans:=ans*(p-) div p;
exit(ans);
end; begin
//sign(input,'a.in');reset(input);
while not eof do
begin
readln(n);
ans:=;
for i:= to trunc(sqrt(n)) do if n mod i= then
begin
inc(ans,i*phi(n div i));
if i*i<>n then inc(ans,(n div i)*phi(i));
end;
writeln(ans);
end;
end.
[BZOJ2190&BZOJ2705]欧拉函数应用两例的更多相关文章
- Bzoj-2190 仪仗队 欧拉函数
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2190 简单的欧拉函数题,实际上就是求gcd(x,y)=1, 0<=x,y<=n ...
- NOIP模拟:切蛋糕(数学欧拉函数)
题目描述 BG 有一块细长的蛋糕,长度为 n. 有一些人要来 BG 家里吃蛋糕, BG 把蛋糕切成了若干块(整数长度),然后分给这些人. 为了公平,每个人得到的蛋糕长度和必须相等,且必须是连续的一段 ...
- 51nod 1363 最小公倍数的和 欧拉函数+二进制枚举
1363 最小公倍数之和 题目来源: SPOJ 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 160 给出一个n,求1-n这n个数,同n的最小公倍数的和.例如:n = 6,1,2,3 ...
- BZOJ2190 [SDOI2008]仪仗队 [欧拉函数]
题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图 ...
- BZOJ2190 [SDOI2008]仪仗队(欧拉函数)
与HDU2841大同小异. 设左下角的点为(1,1),如果(1,1)->(x,y)和(1,1)->(x',y')向量平行,那只有在前面的能被看见.然后就是求x-1.y-1不互质的数对个数. ...
- BZOJ2705: [SDOI2012]Longge的问题(欧拉函数)
题意 题目链接 Sol 开始用反演推发现不会求\(\mu(k)\)慌的一批 退了两步发现只要求个欧拉函数就行了 \(ans = \sum_{d | n} d \phi(\frac{n}{d})\) 理 ...
- 【bzoj2190】[SDOI2008]仪仗队 欧拉函数
题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图 ...
- 【bzoj2705】[SDOI2012]Longge的问题 欧拉函数
题目描述 Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). 输入 一个整数,为N. 输出 ...
- 【bzoj2190】: [SDOI2008]仪仗队 数论-欧拉函数
[bzoj2190]: [SDOI2008]仪仗队 在第i行当且仅当gcd(i,j)=1 可以被看到 欧拉函数求和 没了 /* http://www.cnblogs.com/karl07/ */ #i ...
随机推荐
- allegro导入网表过程中出现的错误信息
1. 找不到焊盘PAD,下面这句话的意思是器件封装找不到焊盘46.pad WARNING(SPMHNI-): Unable to load symbol ): Could not find padst ...
- How to add a webpart to your website
I have download a webpart that can play media on the website from the internet.Then how to add ...
- 关于相对布局RelativeLayout的各种属性介绍
RelativeLayout相对布局是个人觉得在android布局中比较常用且好用的一个,当然如果想让布局更漂亮是需要多种布局混合搭建的,这里就需要更深入的学习了,在这只介绍下有关相对布局的东西. 相 ...
- Assetbundle1
AssetBundle运行时加载:来自文件就用CreateFromFile(注意这种方法只能用于standalone程序)这是最快的加载方法也可以来自Memory,用CreateFromMemory( ...
- UVA 11883 Repairing a Road(最短路径+暴力枚举)
You live in a small town with R bidirectional roads connecting C crossings and you want to go from c ...
- windows bat批处理基础命令学习教程(转载)
一.基础语法: 1.批处理文件是一个“.bat”结尾的文本文件,这个文件的每一行都是一条DOS命令.可以使用任何文本文件编辑工具创建和修改.2.批处理是一种简单的程序,可以用 if 和 goto 来控 ...
- 【Python】Linux crontab定时任务配置方法(详解)
CRONTAB概念/介绍 crontab命令用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行. cron 系统调度进程. 可以使用它在 ...
- html框架集 target
- sqoop将oracle数据导入hdfs集群
使用sqoop将oracle数据导入hdfs集群 集群环境: hadoop1.0.0 hbase0.92.1 zookeeper3.4.3 hive0.8.1 sqoop-1.4.1-incubati ...
- DDX_Control、SubclassWindow和SubclassDlgItem
文章参考地址:http://blog.sina.com.cn/s/blog_86fe5b440101au88.html:http://www.cnblogs.com/riskyer/p/3424278 ...