【问题描述】
从标准输入中输入一个小数,编写程序将其转换成相应的分数显示,即转换为几又几分之几。
要求:
1、输入的小数包括整数部分、小数点和小数部分;整数部分和小数部分分别最多有7位数字;整数部分可以为0,若整数部分为非零整数时,则其最高位不为0;小数部分的末尾数字不为零。
2、输出的分数应为最简分数,由三部分数字组成:第一部分数字代表整数部分(若分数小于1,则为0,否则输出相应分数的整数部分,且最高位不为0),第二部分数字代表分子,第三部分数字代表分母,分子比分母小且不能再约分。
【输入形式】
从标准输入中输入一个小数后打回车。
【输出形式】
将转换后相应分数的三个部分数值输出到标准输出,并且分别以一个空格分隔,最后一个数值后没有空格,有回车换行。
【样例1输入】
0.35
【样例1输出】
0 7 20
【样例2输入】
1050.0144
【样例2输出】
1050 9 625
【样例说明】
样例1中输入的小数为0.35,相应分数整数部分为0,小数部分转换为分数为35/100,约分成最简分数为7/20。
样例2中输入的小数为1050.0144,相应分数整数部分为1050,小数部分转换为分数为144/10000,约分成最简分数为9/625。
#include<cstdio>
#include<iostream>
//#include<algorithm>
using namespace std;
int main()
{ char a;
int t=0,fenmu=1,fenzi=0;
bool p=0;
int h;
while((a=getchar())!='\n')
{
if(a=='.') p=true;
else if(!p&&a<='9'&&a>='0')
{
t=t*10+a-'0';
}
else if(a<='9'&&a>='0')
{
fenmu*=10;
fenzi=fenzi*10+a-'0';
}
}
int m=fenmu,n=fenzi;
h=m%n;
while(h!=0)
{
m=n;
n=h;
h=m%n;
}
fenmu=fenmu/n;
fenzi=fenzi/n;
printf("%d %d %d",t,fenzi,fenmu);
return 0;
}