博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA202 UVALive5141 Repeating Decimals
阅读量:7232 次
发布时间:2019-06-29

本文共 949 字,大约阅读时间需要 3 分钟。

World Finals >> 1990 - Washington

问题链接:。基础训练级的问题,用C语言编写程序。

问题简述输入两个整数numerator和denominator,分别为分子和分母。0≤分子,1≤分母≤3000。输出a/b的循环小数表示以及循环节长度。如果循环周期大于50,只显示50位,之后的全部用“...”表示

问题分析:先取出整数部分(numerator/denominator的商),然后用余数numerator%denominator的余数)计算小数点后的各位。每次将余数先乘以10,就可以取出小数及其余数,循环往复。某两个位余数部分相同则表示,则表示这个区间小数点后的位形成循环

该把该题归类为哪一类,有点困惑,也许归为模拟题是合适的,因为只要模拟人的计算过程就可以了。其实,这个题是一个数学题。

程序说明:程序中,循环控制条件有点变态,但是是正确的。

AC的C语言程序如下:

/* UVA202 UVALive5141 Repeating Decimals */#include 
#define MAXN 3000int decimal[MAXN];int numerator[MAXN];int main(void){ int n, d, start, end, i, j; while(scanf("%d%d", &n, &d) != EOF) { i = 0; numerator[i] = n % d; decimal[i] = numerator[i] * 10 / d; for(i=1; ;i++) { numerator[i] = numerator[i-1] * 10 % d; decimal[i] = numerator[i] * 10 / d; for(j=0; j
50) { for(i=start; i

转载于:https://www.cnblogs.com/tigerisland/p/7564513.html

你可能感兴趣的文章
优化PartialRenderFormMixin性能
查看>>
如何让代码健壮
查看>>
网页布局要点
查看>>
vs2010 VS2008 VS2005 快捷键大全
查看>>
Delphi中调用API函数Winexec执行WinRar命令行压缩工具执行压缩
查看>>
ssm(3-2)Springmvc拓展
查看>>
leetcode--Recover Binary Search Tree*
查看>>
Hdu-6230 2017CCPC-哈尔滨站 A.Palindrome Manacher 主席树
查看>>
提高javascript编码质量-68-1
查看>>
设计模式开篇 - 简单工厂模式
查看>>
Spring MVC 注解和XML的区别
查看>>
利用Swoole实现PHP+websocket直播,即使通讯代码,及linux下swoole安装基本配置
查看>>
Elastic学习第一天遇到的问题以及添加的一些操作
查看>>
Python lambda介绍
查看>>
BSON与JSON的区别
查看>>
文件系统存储数据,与数据库系统存储数据的差别
查看>>
linux之awk
查看>>
第九章 接口
查看>>
XCode4.2.1 使用NavigationController实现View切换
查看>>
如何让NSURLConnection在子线程中运行
查看>>