UVa 10976 - Fractions Again?!
来源:互联网 发布:医疗数据公司 金豆 编辑:程序博客网 时间:2024/04/29 07:25
UVa 10976 - Fractions Again?!
It is easy to see that for every fraction in the form 1/k
(k > 0), we can always find two positive integers
x and y, x ≥ y, such that:
1/k=1/x+1/y
Now our question is: can you write a program that counts how many such pairs of x and y there
are for any given k?
Input
Input contains no more than 100 lines, each giving a value of k (0 < k ≤ 10000).
Output
For each k, output the number of corresponding (x, y) pairs, followed by a sorted list of the values of
x and y, as shown in the sample output.
Sample Input
2
12
Sample Output
2
1/2 = 1/6 + 1/3
1/2 = 1/4 + 1/4
8
1/12 = 1/156 + 1/13
1/12 = 1/84 + 1/14
1/12 = 1/60 + 1/15
1/12 = 1/48 + 1/16
1/12 = 1/36 + 1/18
1/12 = 1/30 + 1/20
1/12 = 1/28 + 1/21
1/12 = 1/24 + 1/24
容易看出y的范围是(k , 2k],x大于等于2k,但上界不确定
因此可看做k和y已知,求是1/k - 1/y结果的分子是否为1
通分后即求k*y是否可被y-k整除
代码如下
#include <iostream>#include <cstdio>#include <cstring>using namespace std;int maxn=100000;int main(){ int n; while(cin>>n){ int i,j,k; int x[maxn],y[maxn]; int cnt=0; for(i=n+1 ; i<= n<<1 ; i++){ if((n*i)%(i-n) == 0){ x[cnt]=(n*i)/(i-n); y[cnt]=i; cnt++; } } cout<<cnt<<endl; for(i=0 ; i<cnt ; i++) printf("1/%d = 1/%d + 1/%d\n",n,x[i],y[i]); } return 0;}
- UVA 10976 - Fractions Again?!
- UVA 10976 - Fractions Again?!
- UVA-10976 - Fractions Again?!
- UVA - 10976 Fractions Again?!
- UVa 10976 - Fractions Again?!
- UVa 10976 - Fractions Again?!
- UVa 10976 - Fractions Again?!
- UVA - 10976 Fractions Again?!
- uva 10976 - Fractions Again?!
- UVa 10976 Fractions Again?!
- Uva - 10976 - Fractions Again?!
- UVA - 10976 Fractions Again?!
- uva 10976Fractions Again?!
- UVA 10976 - Fractions Again?!
- UVA 10976 Fractions Again?!
- UVA 10976 Fractions Again?!
- UVa 10976 Fractions Again?
- UVa 10976 Fractions Again?!
- GRUB启动过程分析 & GRUB 引导程序配置
- 小白日记1:kali环境Wpscan渗透Wordpress
- <Android 应用 之路> MPAndroidChart~PieChart
- 第二周 项目1-C/C++语言中函数参数传递的三种方式
- HDU 1075
- UVa 10976 - Fractions Again?!
- 设计模式
- 我上班就是为了钱,别跟我谈理想
- Java Object类初探
- DOM,SAX,JDOM,DOM4J 四种方式解析xml
- 全志R58的官方开发板加载bmi160驱动的步骤1(测试bma250)
- 基础数论-反素数 ural1748
- Vue.js 框架解析 [图]
- 第二周【项目1-C/++语言中函数参数传递的三种方式】