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++多线程编程(三)线程间通信
多线程编程之三——线程间通讯 作者:韩耀旭 原文地址:http://www.vckbase.com/document/viewdoc/?id=1707 七.线程间通讯 一般而言,应用程序中的一个次要线 ...
- 排序-java
今天座右铭----每天的学习会让我们不断地进步! 往往面试中都会让我们用一种排序方法做一道排序题,下面我就罗列出快速排序.冒泡排序.插入排序.选择排序的java代码! 1.快速排序 public cl ...
- Google Maps API V2
1. 在AndroidManifest.xml的application节点中,添加Google play service的版本号: <meta-data android:name="c ...
- uva 639 Don't Get Rooked 变形N皇后问题 暴力回溯
题目:跟N皇后问题一样,不考虑对角冲突,但考虑墙的存在,只要中间有墙就不会冲突. N皇后一行只能放一个,而这题不行,所以用全图暴力放棋,回溯dfs即可,题目最多就到4*4,范围很小. 刚开始考虑放一个 ...
- Android 启动Activity的方式
Activity的启动分为两种方式,显示方式和隐式方式,显示方式就是在通过intent启动Activity时指定了Activity的包名和类名. 而隐式方式则在初始化Intent时仅仅指定action ...
- DOM4J读取XML文件
最近在做DRP的项目,其中涉及到了读取配置文件,用到了DOM4J,由于是刚开始接触这种读取xml文件的技术,好奇心是难免的,于是在网上又找了一些资料,这里就结合找到的资料来谈一下读取xml文件的4中方 ...
- 初探swift语言的学习笔记(闭包-匿名函数或block块代码)
使用Block的地方很多,其中传值只是其中的一小部分,下面介绍Block在两个界面之间的传值: 先说一下思想: 首先,创建两个视图控制器,在第一个视图控制器中创建一个UILabel和一个UIButto ...
- HDU1963 && POJ2063:Investment(完全背包)
Problem Description John never knew he had a grand-uncle, until he received the notary’s letter. He ...
- SQL练习之求解填字游戏
SELECT * FROM dbo.spt_values
- 征服 Redis + Jedis + Spring —— 配置&常规操作
Spring提供了对于Redis的专门支持:spring-data-redis.此外,类似的还有: 我想大部分人对spring-data-hadoop.spring-data-mongodb.spri ...