实现功能:求出1-N的欧拉函数,然后应对若干个询问操作
其实就是个素数判定+欧拉函数性质的二合一
代码如下,我觉得应高不难懂,只要你知道欧拉函数的性质
var
i,j,k,l,m,n:longint;
a,b:array[0..10000005] of longint;
procedure phi;
var i,j:longint;
begin
m:=0;a[1]:=1;
for i:=2 to n do
begin
if a[i]=0 then
begin
inc(m);
b[m]:=i;
a[i]:=i-1;
end;
for j:=1 to m do
begin
if (i*b[j])>n then break;
if (i mod b[j])=0 then
a[i*b[j]]:=a[i]*b[j]
else
a[i*b[j]]:=a[i]*(b[j]-1);
end
end;
end;
begin
readln(n);phi;
while true do
begin
readln(j);
writeln(a[j]);
end;
end.
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有