CUG 数学进阶
题目链接:http://acm.cug.edu.cn/JudgeOnline/contest.php?cid=1047
.
.
.
I 题目链接:http://acm.cug.edu.cn/JudgeOnline/problem.php?cid=1047&pid=8
题意:给你一个0.xxx...表示的无限循环小数,求其表示成分数形式时分母最小的那个分式。
思路:首先我们要知道如何将一个无限循环小数(已知循环结)化为分数,剩下的过程就是枚举所有循环结来寻找满足题目要求的答案。
下面来推导下如何将一个无限循环小数化为分数:
X = 0.a1a2…an(b1b2…bm) (1)
X *10^n = a1a2…an. (b1b2…bm) (2)
X *10^n - a1a2…an = 0. (b1b2…bm) (3)
(X *10^n - a1a2…an)*10^m = b1b2…bm. (b1b2…bm) (4)
(X *10n - a1a2…an)*10^m - b1b2…bm = 0. (b1b2…bm) (5)
(3)和(5)相等,联立解得:
X = (a1a2...anb1b2...bm - a1a2...an)/(10^(n+m) - 10^n) (*)
求出了(*)题目就基本做出来了。
** 使用%[]格式可以输入一个字符集,scanf(" 0.%[0-9]...")格式可以输入前面是0.开头后面是...结尾,中间是由0-9内范围的数字字符组成。
关于更多的字符串输入格式可以参见以前的博文C/C++中字符串的输入问题
** atio函数的介绍
头文件:#include <stdlib.h>
函数原型:int atoi( const char *str );
函数功能:将字符串str转换成一个整数并返回结果。参数str 以数字开头,当函数从str 中读到非数字字符则结束转换并将结果返回。
返回值:字符串的整数表示形式
code:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
using namespace std;
const int MAXN = ;
typedef long long LL;
char str[MAXN];
char ups[MAXN];
char dws[MAXN]; LL gcd(LL a, LL b)
{
return !b ? a : gcd(b, a % b);
} int main()
{
while (scanf(" 0.%[0-9]...", str) == )
{
int len = strlen(str);
if (str[] == '' && len == ) break;
LL ansu, ansd; // 分别存储分子和分母
ansd = ;
for (int i = ; i < len; ++i)
{
strncpy(ups, str, i); // 拷贝前i个字符到ups作为非循环部分
ups[i] = ; // 添加字符串结束符
strcpy(dws, str + i); // 从第i个字符开始拷贝给dws(包括字符串结束符),作为循环部分
int lu = strlen(ups);
int ld = strlen(dws);
LL up = atoi(ups) * (pow(, ld) - ) + atoi(dws); // 计算分子(atoi函数将字符串转换成一个整数并返回结果)
LL down = pow(, lu + ld) - pow(, lu); // 计算分子
LL d = gcd(down, up); // 计算最大公约数,分子分母约分
up /= d;
down /= d;
if (down < ansd) // 更新分子和分母
{
ansu = up;
ansd = down;
}
}
printf("%lld/%lld\n", ansu, ansd); // 输出分母最小的结果
}
return ;
}
CUG 数学进阶的更多相关文章
- MySQL 进阶4 SQL常见函数: 字符函数/数学函数/日期函数/流程控制函数(if/case)
		# 进阶4 SQL常见函数 分类: 1/单行函数: 字符函数: concat(),length(),ifnull(__,default) ,instr(), trim(),upper(),lower( ... 
- 「【算法进阶0x30】数学知识A」作业简洁总结
		t1-Prime Distance 素数距离 大范围筛素数. t2-阶乘分解 欧拉筛素数后,按照蓝皮上的式子筛出素数. 复杂度:O(nlogn) t3-反素数ant 搜索 t4-余数之和 整除分块+容 ... 
- 3D数学读书笔记——矩阵进阶
		本系列文章由birdlove1987编写,转载请注明出处. 文章链接:http://blog.csdn.net/zhurui_idea/article/details/25242725 最终要学习矩阵 ... 
- [C#] 进阶 - LINQ 标准查询操作概述
		LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ... 
- ACM进阶计划
		ACM进阶计划ACM队不是为了一场比赛而存在的,为的是队员的整体提高.大学期间,ACM队队员必须要学好的课程有:lC/C++两种语言l高等数学l线性代数l数据结构l离散数学l数据库原理l操作系统原理l ... 
- OpenGL坐标变换及其数学原理,两种摄像机交互模型(附源程序)
		实验平台:win7,VS2010 先上结果截图(文章最后下载程序,解压后直接运行BIN文件夹下的EXE程序): a.鼠标拖拽旋转物体,类似于OGRE中的“OgreBites::CameraStyle: ... 
- 一些对数学领域及数学研究的个人看法(转载自博士论坛wcboy)
		转自:http://www.math.org.cn/forum.php?mod=viewthread&tid=14819&extra=&page=1 原作者: wcboy 现在 ... 
- [.net 面向对象程序设计进阶] (2) 正则表达式 (一) 快速入门
		[.net 面向对象程序设计进阶] (2) 正则表达式 (一) 快速入门 1. 什么是正则表达式? 1.1 正则表达式概念 正则表达式,又称正则表示法,英文名:Regular Expression(简 ... 
- 在数学建模中学MATLAB
		为期三周的数学建模国赛培训昨天正式结束了,还是有一定的收获的,尤其是在MATLAB的使用上. 1. 一些MATLAB的基础性东西: 元胞数组的使用:http://blog.csdn.net/z1137 ... 
随机推荐
- 有哪些适合学生参与的 C++,网络编程方面的开源项目?
			有哪些适合学生参与的 C++,网络编程方面的开源项目? Tinyhttpd是一个超轻量型Http Server,使用C语言开发,全部代码只有502行(包括注释),附带一个简单的Client,可以通 ... 
- Http静态资源的缓存
			最近一段时间一直在研究页面缓存和压缩方面的东西,由于公司服务器使用的是iis6.0,很多性能方面的优化都不支持.所以,就开始尝试着自己写个简单的处理程序. 为了减少服务器带宽的需求,我们要减少客户端与 ... 
- UberX及以上级别车奖励政策(优步北京第一组)
			优步北京第一组: 定义为2015年6月1日凌晨前(不含6月1日)激活的司机(以优步后台数据显示为准) 滴滴快车单单2.5倍,注册地址:http://www.udache.com/如何注册Uber司机( ... 
- #include <string>
			1 append(string T&);字符串拼接 2 c_str string.c_str是Borland封装的String类中的一个函数,它返回当前字符串的首字符地址. 3 empty() ... 
- C#反射动态赋值
			很多时候我们需要在数据实体层读取数据后赋值到领域模型时往往会产生如下的代码 public class A { public string Name {get;set;} public int Age ... 
- Ext.Net 使用总结之GridPanel中的选中行
			1.判断GridPanel中是否选中了某行 if (!GridPanel1.hasSelection()) { Ext.Msg.alert("提示", "请选择记录!&q ... 
- Css 外边距折叠(collapsed margin ) 浅析
			Css 外边距折叠(collapses margin ) a.先来看看w3c 文档对于外边距折叠的定义: In CSS, the adjoining margins of two or more bo ... 
- vlan trunk vtp端口聚合
			第一步:端口聚合(两端都需要做相同的操作) 第二步:在服务器端配置为服务器模式 第四步:在服务器端添加vlan 第五步:在两端分别将不同的端口添加到不同的vlan 
- NXT项目准备资料
			聊天资源 http://www.cocoachina.com/ios/20150205/11116.html https://developer.layer.com/docs/ios/quick-st ... 
- ubuntu14.04下手动安装JDK + eclipse + Pydev
			说明:本文在root用户下进行,如不是root用户命令前加sodu 一.手动安装JDK 1.下载JDK 从官网http://www.oracle.com/technetwork/java/javase ... 
