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 ...
随机推荐
- Ubuntu 下开发环境的常规配置。
Install Chinese input (for Chinese peers) We Choose the Sougou pinying.(搜狗) $ sudo apt-get install g ...
- paip.c++ qt 项目工程互相引用的方法
paip.c++ qt 项目工程互相引用的方法 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/ ...
- SQL高级查询
高级查询: 一.多表链接 1,普通查询 select * from 表名,表名 where 表名.列名 = 表名.列名 2,join链接 select * from 表名 join 表名 on 表名. ...
- 面向对象程序设计-C++_课时17函数重载和默认参数
函数重载,区别一是参数类型不同,二是参数个数不同. 默认参数可以多于1个,但必须放在参数序列的后部. 尽量不要用默认参数,会影响阅读 error C2668: “f”: 对重载函数的调用不明确 #in ...
- iOS实现文件上传功能模块
iOS实现文件上传功能,首先要知道的是,上传到服务器的数据格式,一般采用HTTP文件上传协议.如下图 如图所示,只要设置好了HTTP的协议格式,就可以实现文件上传功能. 代码如下: //图片上传模块 ...
- Android开发(27)--TextView单击链接弹出Activity
话不多说直接上码: 核心源码: package com.example.textview4; import android.app.Activity; import android.content.I ...
- oracle11g ora-12514监听程序当前无法识别
环境:win7_x64 ,oracle11g 描写叙述:1第一天没问题,第二天就不能连接: 2:pl sql developer连接工具,自己安装的oracle数据库,又装了client 3:装了or ...
- Jave中System.getProperty()获取的值
java.version Java 执行时环境版本号 java.vendor Java 执行时环境供应商 java.vendor.url Java 供应商的 URL java.home Java 安装 ...
- hdu-4468-Spy-KMP+贪心
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4468 题目意思: 给你一个串r,求一个串s,使得s的前缀1+s的前缀2+s的前缀3+...+s的前缀 ...
- Fedora安装theano
Fedora下安装theano Fedora下安装theano Theano的安装依赖很多包,有必须的,有可选的.此外,python版本必须大于2.6,请在shell直接键入python,如果小于2. ...