Problem H: 2.4.5 Fractions to Decimals 分数化小数

Problem H: 2.4.5 Fractions to Decimals 分数化小数

Time Limit: 1 Sec   Memory Limit: 64 MB
Submit: 326   Solved: 72
[ Submit][ Status][ Web Board]

Description

写一个程序,输入一个形如N/D的分数(N是分子,D是分母),输出它的小数形式。 如果小数有循环节的话,把循环节放在一对圆括号中。例如, 1/3 = .33333333 写成0.(3) 41/333 = 0.123123123... 写成0.(123) 用xxx.0 成表示整数 典型的转化例子: 1/3 = 0.(3) 22/5 = 4.4 1/7 = 0.(142857) 2/2 = 1.0 3/8 = 0.375 45/56 = 0.803(571428)

Input

单独的一行包括被空格分开的 N和D, 1 <= N,D <= 100000。

Output

小数的表示方法上面说的很明白了,如果输出的长度超过76个字符,每行输出76个。

Sample Input

45 56

Sample Output

0.803(571428)
<span style="font-size:14px;">#include <stdio.h>  
#include <string.h>  
#define N 100010  
int rm[N],c;  
char buf[N],dev[N];  
int main()  
{  
    int m,n,i;  
    scanf("%d%d",&m,&n);  
    sprintf(buf,"%d.",m/n);  
    memset(rm, -1, sizeof(rm));  
    m = m % n;  
    dev[0] ='0';  
    for(i= 0;; i++)  
    {  
        if(m==0)  
        {  
            sprintf(buf + strlen(buf),"%s", dev);  
            break;  
        }  
        if(rm[m]!= -1)  
        {  
            sprintf(buf + strlen(buf), "%.*s(%s)", rm[m], dev, dev + rm[m]);  
            break;  
        }  
        rm[m] = i;  
        m *= 10;  
        dev[c++] = m / n + '0';  
        m = m % n;  
    }  
    for(i = 0; i<(int)strlen(buf); i+=76)printf("%.76s\n", buf + i);  
    return 0;  
} 
 </span>


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值