【NOIP2018复习】可见点数【数论】

1268.可见点数

时间限制:1000MS内存限制:65536KB

题目描述

ZPS经过长期的努力争取,终于成为了0901班的领操员,他要带领0901班参加广播操比赛。现在0901班的队伍可以看作是一个n*n的点阵,每个人都站在格点上。现在作为领操员的ZPS站(0,0)点,他想知道如果0901班的队伍站齐了,他能看到多少个人的脸(假设每个人的身高相同,体积相同)。
 

输入

一个正整数n。

输出

ZPS能看到多少个人的脸(当然他是看不到自己的脸的)。

输入样例复制

3

输出样例复制

5

说明

Data Constraint 40%的数据,n<=1500。 100%的数据,n<=100000。

题解:直观看求斜率不一样的直线个数,易得出(x,y)与(0,0)得到一根新的直线的要求是x,y互质,因为x,y不互质,必然存在(x div k,y div k)在之前出现过  k=gcd(x,y)。问题转化为线性筛求欧拉函数
欧拉函数性质:1. φ(x*y)=φ(x)*φ(y)  (x,y互质)

                         2.φ(x)=x-1                     (x为质数)
                         3.φ(x*y)=φ(x)*y              (x mod y=0) 

const

  maxn=100000;

var

  phi:array[1..maxn]of int64;

  ans,f,prime:array[0..maxn]of int64;

  n,i:longint;

procedure init;

var

  i,pp,j:longint;

begin

  phi[1]:=1;  //phi(1)=1

  for i:=2 to maxn do

  begin

    if f[i]=0 then

    begin

      inc(prime[0]);

      prime[prime[0]]:=i;

      phi[i]:=i-1;

    end;

    for j:=1 to prime[0] do

    begin

      pp:=i*prime[j];

      if pp>maxn then break;

      f[pp]:=1;

      if i mod prime[j]=0 then phi[pp]:=phi[i]*prime[j] //(x mod y=0)

      else phi[pp]:=phi[i]*phi[prime[j]]; 

    end;

  end;

  ans[1]:=0;ans[2]:=3;

  for i:=3 to n do

    ans[i]:=ans[i-1]+phi[i-1]*2;

end;

begin

  readln(n);

  init;

  writeln(ans[n]);

end.

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值