上小学的时候,小明经常自己发明新算法。一次,老师出的题目是:1/4 乘以 8/5
小明居然把分子拼接在一起,分母拼接在一起,答案是:18/45 , 老师刚想批评他,转念一想,这个答案凑巧也对啊,真是见鬼!对于分子、分母都是 1~9 中的一位数的情况,还有哪些算式可以这样计算呢? 请写出所有不同算式的个数。
显然,交换分子分母后,例如:4/1 乘以 5/8 是满足要求的,这算做不同的算式。 但对于分子分母相同的情况,2/2 乘以 3/3 这样的类型太多了,不在计数之列! 请输出所有满足小明新算法的分式组合,以及这类分数组合的个数。
输入
输出
1/2 5/4
1/4 8/5
1/6 4/3
1/6 6/4
…
9/4 8/9
n
#include <stdio.h>
int main()
{
int a,b,c,d,n=0;
for(a=1;a<10;a++)
{
for(b=1;b<10;b++)
{
for(c=1;c<10;c++)
{
for(d=1;d<10;d++)
{
if(a==b&&c==d)
continue;
if((a*c)*(b*10+d)==((b*d)*(a*10+c)))
{
n++;
printf("%d/%d %d/%d\n",a,b,c,d);
}
}
}
}
}
printf("%d\n",n);
return 0;
}
以原题为例,1/4乘以8/5等于18/45,若用正常算法解题,应为8/20,约分后都是2/5,用字母表示a/b乘以c/d:(10a+c)/(10b+d)=ac/bd,根据数学知识去分母,(10a+c)(bd)=(10b+d)(ac)
题目中提到,分子分母相同的情况不计数,可以用continue语句(作用是跳过本循环中剩余的语句而强制执行下一次循环),将这种情况舍弃。