http://poj.org/problem?id=2478

此题只是用简单的欧拉函数求每一个数的互质数的值会超时,因为要求很多数据的欧拉函数值,所以选用欧拉函数打表法。

PS:因为最后得到的结果会很大,所以结果数据类型不要用int,改为long long就没问题了

#include <iostream>
#include <stdio.h>
using namespace std;
#define LL long long
LL F[];
int phi[]; void phi_table(int n)
{
for(int i=;i<=n;i++)phi[i]=;
phi[]=;
for(int i=;i<=n;i++)
if(!phi[i])
for(int j=i;j<=n;j+=i)
{
if(!phi[j])phi[j]=j;
phi[j]=phi[j]/i*(i-);
}
} int main()
{
int n;
F[]=;
phi_table();
for(int i=;i<=;i++) F[i] = F[i-]+phi[i];
while(scanf("%d",&n)&&n!=){
cout<<F[n]<<endl;
}
return ;
}

最新文章

  1. 当GitHub把我当成DDos攻击者拉进了黑名单中。。。
  2. 项目修改有感_主要是以js、Gridview为主
  3. 通过HTTP协议实现多线程下载
  4. 洛谷P2085 最小函数值(minval)
  5. 【BZOJ】【1986】【USACO 2004 Dec】/【POJ】【2373】划区灌溉
  6. ubuntu下安装pthread的manpages(man 手册) 在Ubuntu中查看STL帮助
  7. java代码转换为c# 工具
  8. HDU 5794 - A Simple Chess
  9. (大数据工程师学习路径)第四步 SQL基础课程----SQL介绍及mysql的安装
  10. css05 字体以及行间距
  11. 模拟select,隐藏下拉列表的几种实现
  12. 把java程序作为windows服务运行
  13. LINQ Group By操作(转载)
  14. 【转】浅谈JavaScript中forEach与each
  15. HTTP response 添加body
  16. 2.15 C++常量指针this
  17. 【Spring学习笔记-4】注入集合类List、Set、Map、Pros等
  18. Day 38 Semaphore ,Event ,队列
  19. Linux操作系统多线程信号总结
  20. ButterKnife 8.4注入失败

热门文章

  1. [转]Android 完美退出 App (Exit)
  2. html引入另一个html
  3. C#局部类型partial在定义实体类Model中的应用
  4. MySQL系列:utf8_bin和utf8_general_ci编码的区别
  5. SSM-WebMVC(三)
  6. JVM(HotSpot)7种垃圾收集器
  7. RSA2
  8. centos 更换yum源 (解决下载慢的问题)
  9. Fire Air(华科校赛 网络赛)
  10. DROP AGGREGATE - 删除一个用户定义的聚集函数