hdoj-【3501 Calculation 2】
来源:互联网 发布:淘宝介入卖家给假地址 编辑:程序博客网 时间:2024/05/22 13:12
Calculation 2
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3791 Accepted Submission(s): 1587
Problem Description
Given a positive integer N, your task is to calculate the sum of the positive integers less than N which are not coprime to N. A is said to be coprime to B if A, B share no common positive divisors except 1.
Input
For each test case, there is a line containing a positive integer N(1 ≤ N ≤ 1000000000). A line containing a single 0 follows the last test case.
Output
For each test case, you should print the sum module 1000000007 in a line.
Sample Input
340
Sample Output
02
#include<cstdio>typedef long long LL;#define M 1000000007int main(){LL n;while(~scanf("%lld",&n),n){LL i,ans=n,temp=n,sum1,sum2;for(i=2;i*i<=n;++i){if(n%i==0)ans=ans*(i-1)/i;while(n%i==0)n/=i; } if(n!=1)ans=ans*(n-1)/n;sum1=ans*temp/2;//计算所有和n互质的数的和 sum2=temp*(temp-1)/2;//求出1-n-1的和 //printf("%lld\n",sum1);//printf("%lld\n",sum2); printf("%lld\n",(sum2-sum1)%M); } return 0;}
0 0
- hdoj 3501 Calculation 2
- HDOJ 3501 Calculation 2
- hdoj-3501-Calculation 2
- hdoj-【3501 Calculation 2】
- 【欧拉函数】 HDOJ 3501 Calculation 2
- hdoj 3501 Calculation 2 【欧拉函数】
- hdoj 3501 Calculation 2(欧拉函数)
- hdoj-3501-Calculation 2-欧拉函数
- HDOJ Calculation 2 3501(eular函数)
- HDOJ 题目3501 Calculation 2(欧拉函数)
- hdoj 3501 Calculation 2(欧拉函数的延伸)
- HDOJ 3501 Calculation 2 (欧拉函数)
- hdoj Calculation 2 3501 (欧拉函数)
- hdu 3501 Calculation 2
- hdu 3501 Calculation 2
- hdu 3501 Calculation 2
- hdu 3501 Calculation 2
- HDU 3501 Calculation 2
- 哈尔滨理工大学软件学院ACM程序设计全国邀请赛
- 命令完毕自动发送邮件提醒执行结果
- SQL优化方法
- 欢迎使用CSDN-markdown编辑器
- POJ 3171 Cleaning Shifts 已被翻译
- hdoj-【3501 Calculation 2】
- The Accomodation of Students---hdu2444
- 分数变成小数(四舍五入)
- 概率图模型学习(6)——高斯网络模型1
- nginx的相关配置项
- (大学生)保持乐观的心态
- DOM事件流详解
- static-001
- Andriod应用性能测试-流量、电量