HDU1717小数化分数2

小数化分数2

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4278    Accepted Submission(s): 1725


Problem Description
Ray 在数学课上听老师说,任何小数都能表示成分数的形式,他开始了化了起来,很快他就完成了,但他又想到一个问题,如何把一个循环小数化成分数呢?
请你写一个程序不但可以将普通小数化成最简分数,也可以把循环小数化成最简分数。
 

 

Input
第一行是一个整数N,表示有多少组数据。
每组数据只有一个纯小数,也就是整数部分为0。小数的位数不超过9位,循环部分用()括起来。
 

 

Output
对每一个对应的小数化成最简分数后输出,占一行。
 

 

Sample Input
3 0.(4) 0.5 0.32(692307)
 

 

Sample Output
4/9 1/2 17/52
 

 

Source
 

 

Recommend
lcy   |   We have carefully selected several similar problems for you:   1715  1716  1166  1719  1722 
# include<stdio.h>
int gcd(int a,int b)
{
    int temp;
    while(a%b!=0)
    {
        temp=a%b;
        a=b;
        b=temp;
    }
    return b;
}
int main()
{
    int i,ncase,ans,p,q,t,m,n,x,y,k,l;
    char ch[25];
    scanf("%d",&ncase);
    while(ncase--)
    {
        scanf("%s",ch);
        x=0;
        t=0;
        p=0;
        q=0;
        k=1;l=1;
        for(i=2;ch[i]!=0;i++)
        {
            if(t==0 && ch[i]!='(')
            {
                p++;
                x*=10;
                x+=ch[i]-'0';
            }
            if(t==1&& ch[i]!=')')
            {
                q++;
                y*=10;
                y+=ch[i]-'0';
            }
            if(ch[i]=='(') {t=1;y=x;q=p;}
        }
        if(q==0)
        {
            while(p--)
                k*=10;
            ans=gcd(x,k);
            x/=ans;
            k/=ans;
            printf("%d/%d\n",x,k);
        }
        else
        {
            m=y-x;
            while(p--)
                k*=10;
            while(q--)
                l*=10;
            n=l-k;
            ans=gcd(m,n);
            m/=ans;
            n/=ans;
            printf("%d/%d\n",m,n);
        }
    }
    return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值