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

最新文章

  1. WCF入门教程系列一
  2. [Java Web]Struts2解决中文乱码问题
  3. CD冷却效果实现
  4. STM 8s 外部中断寄存器无法写入
  5. mac pycharm快捷键整理
  6. WordPress添加显示和隐藏侧边栏按钮开关
  7. 一文读懂阻塞、非阻塞、同步、异步IO
  8. Java开发笔记(十一)常见的数学函数
  9. 利用RALL机制来事项String类的赋值操作
  10. Vue-admin工作整理(十九):从数字渐变组件谈第三方JS库Count-to的使用
  11. HTML基础总结
  12. CodeForces - 660D:Number of Parallelograms (问N个点多少个平行四边形)
  13. block详解
  14. model browser 不出现时
  15. 洛谷.3381.[模板]最小费用最大流(zkw)
  16. IntelliJ IDEA的黑白色背景切换(Ultimate和Community版本皆通用)
  17. tomcat 开启远程debug
  18. Flyway学习笔记
  19. MySQL 字段类型占用空间
  20. Linux Ubuntu下软件包管理

热门文章

  1. ftp链接、上传、下载、断开
  2. PHP文件上传设置和处理(多文件)
  3. Spring 定时器 定时访问数据库并发送邮件
  4. BZOJ 1090 字符串折叠(Hash + DP)
  5. C#/.NET基于Topshelf创建Windows服务的守护程序作为服务启动的客户端桌面程序不显示UI界面的问题分析和解决方案
  6. CMDB资产管理系统的数据表设计
  7. JS标签获取另一个页面传过来的href值
  8. Google的JSON风格指南
  9. Android新技术学习——阿里巴巴免Root无侵入AOP框架Dexposed
  10. SolidEdge如何绘制阵列之后取消掉某一些