HDOJ 1286 找新朋友
来源:互联网 发布:黑马协议软件微信站街 编辑:程序博客网 时间:2024/05/18 06:29
找新朋友
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9810 Accepted Submission(s): 5186
Problem Description
新年快到了,“猪头帮协会”准备搞一个聚会,已经知道现有会员N人,把会员从1到N编号,其中会长的号码是N号,凡是和会长是老朋友的,那么该会员的号码肯定和N有大于1的公约数,否则都是新朋友,现在会长想知道究竟有几个新朋友?请你编程序帮会长计算出来。
Input
第一行是测试数据的组数CN(Case number,1<CN<10000),接着有CN行正整数N(1<n<32768),表示会员人数。
Output
对于每一个N,输出一行新朋友的人数,这样共有CN行输出。
Sample Input
22560824027
Sample Output
768016016
法一:筛选法
#include <cstdio>#include <cstring>using namespace std;int main(){ int a[33000]; int t, N, i, j, k, n, m; scanf("%d", &t); while (t-- && scanf("%d", &N)){ int sum = 0; memset(a, 0, sizeof(a)); for (i = 2; i <= N / 2; i++){ if (N % i == 0){ for (j = i; j < N; j = j + i){ if (a[j] == 0) a[j] = 1; } } } for (i = 1; i < N; i++){ if (a[i] == 1){ sum += a[i]; } } printf("%d\n", i - sum - 1); } return 0;}
法二:欧拉函数
#include <cstdio>#include <cstring>using namespace std;int euler(int n){ int ret = n, i; for (i = 2; i * i <= n; i++){ if (n % i == 0){ ret = ret - ret / i; while (n % i == 0) n = n / i; } } if (n > 1) ret = ret - ret / n; return ret;}int main(){ int t; int N; scanf("%d", &t); while (t-- && scanf("%d", &N)){ printf("%d\n", euler(N)); } return 0;}
0 0
- HDOJ 1286 找新朋友
- hdoj 1286 找新朋友
- hdoj 1286 找新朋友
- hdoj-1286-找新朋友
- hdoj 1286找新朋友
- hdoj 1286 找新朋友
- hdoj 1286 找新朋友
- HDOJ 1286 找新朋友
- HDOJ 1286找新朋友
- hdoj-【1286 找新朋友】
- hdoj找新朋友
- hdoj 1286 找新朋友【水】
- hdoj.1286 找新朋友 20140724
- hdoj 1286 找新朋友(求欧拉函数)
- HDOJ 题目1286找新朋友(打表,水题)
- hdoj 1286 找新朋友 【数论之欧拉函数】
- hdoj 1286 找新朋友(欧拉函数)
- HDOJ 1286 找新朋友(欧拉函数)
- Oracle 11g 安装图文步骤
- sparkR在spark on yarn下的问题
- Java初学习 - 线程同步的一点说明
- awk 精萃
- MTk屏幕切换效果的制作
- HDOJ 1286 找新朋友
- Groovy入门教程
- 软件架构学习小结
- LeetCode 12 - Integer to Roman
- 数据结构制冒泡排序算法—PHP
- leetcode -- Wildcard Matching --再看
- NSDictionary之objectForKey 和 valueForKey 的不同
- 第四章 Controller接口控制器详解(1)
- iOS面试题