![]() ![]() |
|
C趣味编程百例(13)分数之和 | |
作者:佚名 文章来源:不详 点击数 更新时间:2008/4/18 13:59:24 文章录入:杜斌 责任编辑:杜斌 | |
|
|
求这样的四个自然数p,q,r,s(p<=q<=r<=s),使得以下等式成立:
若规定p<=q<=r<=s,将原式通分、化简并整理后得到: 2<=p<5 p<=q<7 q<r<13 采用最简单的穷举方法可以很方便的求解。 程序与程序注释: #include<stdio.h> void main() { int p,q,r,s,count=0; printf("The 4 fractions which sum is equal 1 are:\n"); for(p=2;p<5;p++) /*穷举分母*/ for(q=p;q<7;q++) for(r=q;r<13;r++) if(p*q*r-q*r-p*r-p*q!=0) { s=(p*q*r)/(p*q*r-q*r-p*r-p*q); /*求出s的值*/ if(!((p*q*r)%(p*q*r-q*r-p*r-p*q))&&s>=r) printf("[%2d] 1/%d+1/%d+1/%d+1/%d=1\n",++count,p,q,r,s); /*输出结果*/ } } *运行结果
将1、2、3、4、5、6、7、8、9九个数字分成以下三种分数形式之一,每个数字只能用一次,使得该分数刚好等于一个整数。
求所有满足条件的表示形式。 (参考答案:某些自然数没有这种表示形式,如:1、2、3、4、15、18等。此外整数100有11种满足条件的表示形式;89的表示形式最多,共有36种;三种形式中,最大可表示的整数为794。)
|
|
![]() ![]() |