HDOJ-1787-GCD Again 解题报告
来源:互联网 发布:淘宝特惠囤 编辑:程序博客网 时间:2024/06/01 20:46
求欧拉函数单值,水题。题意:给你一个数n,求出大于0小于n的正整数中与n的最大公约数大于1的数的个数。
我的解题思路:与n的公约数大于1的数的个数就是与n不互素的数的个数。这里有个坑,首先就是小于n,因此输出应该是n - 1 - phi(n)。
我的解题代码:
#include <stdio.h>#include <cstdlib>#include <cstring>#include <cctype>#include <cmath>#include <algorithm>using namespace std;int Phi(int x);int main(){ int x; while (~scanf("%d", &x)) { if (x == 0) break; printf("%d\n", x - 1 - Phi(x)); } return 0;}int Phi(int x){ int ans = x; int cnt = (int)sqrt(x + 0.5) + 1; for (int i=2; i<cnt; ++i) { if (x % i == 0) { ans -= ans / i; while (x % i == 0) x /= i; } } if (x > 1) ans -= ans / x; return ans;}
0 0
- HDOJ-1787-GCD Again 解题报告
- 杭电“GCD Again ”解题报告
- HDOJ 1021 Fibonacci Again解题报告
- HDOJ-5019-Revenge of GCD 解题报告
- HDOJ GCD Again 1787【欧拉函数】
- HDOJ-1787 GCD Again(欧拉函数)
- HDOJ 1239:Calling Extraterrestrial Intelligence Again 解题报告
- POJ-1411 & HDOJ-1239 Calling Extraterrestrial Intelligence Again 解题报告
- HDOJ-5175-Misaki's Kiss again 解题报告
- Fibonacci Again解题报告
- hdoj 1787 GCD Again(欧拉函数)
- HDOJ 题目1787 GCD Again(欧拉函数)
- HDOJ 1787 GCD Again(欧拉函数)
- HDOJ 1787 GCD Again (欧拉函数)
- hdoj GCD Again 1787 (欧拉函数)
- hdoj 1787 GCD Again (欧拉函数模板 )
- HDOJ 1787 GCD Again (欧拉函数)
- HDOJ 1020解题报告
- Coursera机器学习基石 第2讲:感知器
- json转java对象
- iOS开发之打包上传到App Store——(二)开发/发布流程
- Android的图形与图像处理之一 使用简单图片&绘图
- 蛇形填数(矩阵)
- HDOJ-1787-GCD Again 解题报告
- Android的图形与图像处理之二 图形特效处理
- WebService之WSDL和SOAP实例(基于JAVA)
- Android的图形与图像处理之三 逐帧动画(Frame)
- 读head first servlet and jsp(二)
- webservice:Axis2
- The Blocks Problem
- Android的图形与图像处理之四 补间动画(Tween)
- 使用Jenkins进行持续集成(一)-安装篇