YTU 1439: 2.4.5 Fractions to Decimals 分数化小数

1439: 2.4.5 Fractions to Decimals 分数化小数

时间限制: 1 Sec  内存限制: 64 MB
提交: 194  解决: 13

题目描述

写一个程序,输入一个形如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)

输入

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

输出

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

样例输入

45 56

样例输出

0.803(571428)

迷失在幽谷中的鸟儿,独自飞翔在这偌大的天地间,却不知自己该飞往何方……

#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
", buf + i);
    return 0;
}

原文地址:https://www.cnblogs.com/im0qianqian/p/5989422.html