热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

将小数转换为最简分数的方法与实现

Ray在数学课上了解到,任何小数都可以表示成分数的形式。他在尝试将普通小数转换为分数的过程中,进一步思考了如何将循环小数也转换为最简分数。本文将介绍一种算法,不仅能够处理普通小数,还能处理循环小数。

Ray在数学课上听老师讲解,得知任何小数都可以表示成分数的形式。他尝试将普通小数转换为分数,并很快完成了任务。然而,他又提出了一个新的问题:如何将循环小数转换为最简分数?本文将介绍一种算法,不仅能将普通小数转换为最简分数,还能处理循环小数。

### 问题描述

给定一个纯小数(即整数部分为0),需要将其转换为最简分数。小数的位数不超过9位,循环部分用括号表示。

### 输入格式

输入的第一行是一个整数N,表示有N组数据。每组数据包含一个纯小数,小数的位数不超过9位,循环部分用括号表示。

### 输出格式

对于每一组数据,输出其对应的最简分数,每组数据占一行。

### 示例

输入:

3
0.(4)
0.5
0.32(692307)

输出:

4/9
1/2
17/52

### 算法思路

1. **普通小数**:直接将小数转换为分数,然后通过最大公约数(GCD)化简。

2. **循环小数**:将小数分为非循环部分和循环部分。分母由循环部分的位数决定,每有一位循环部分,分母就多一个9;每有一位非循环部分,分母就多一个0。分子则由非循环部分加上循环部分的值减去非循环部分的值。

### 代码实现

#include 
#include
#include
using namespace std;

int Gcd(int x, int y) {
while (y) {
int temp = y;
y = x % y;
x = temp;
}
return x;
}

void ConvertToFraction(char *s) {
int len = strlen(s);
int nOnRepeating= 0, repeating = 0;
int numerator = 0, denominator = 0;
bool isRepeating = false;

for (int i = 2; i if (s[i] == '(') {
isRepeating = true;
break;
}
nOnRepeating= nonRepeating * 10 + (s[i] - '0');
}

for (int i = 2; i if (s[i] == '(' || s[i] == ')') continue;
repeating = repeating * 10 + (s[i] - '0');
}

if (!isRepeating) {
denominator = 1;
for (int i = 0; i denominator *= 10;
}
numerator = repeating;
} else {
int nOnRepeatingLen= strlen(s) - 2 - (len - s[i] - 1);
int repeatingLen = len - s[i] - 2;
denominator = 0;
for (int i = 0; i denominator = denominator * 10 + 9;
}
for (int i = 0; i denominator *= 10;
}
numerator = repeating - nonRepeating;
}

int gcd = Gcd(numerator, denominator);
printf("%d/%d\n", numerator / gcd, denominator / gcd);
}

int main() {
int N;
scanf("%d", &N);
while (N--) {
char s[20];
scanf("%s", s);
ConvertToFraction(s);
}
return 0;
}

推荐阅读
  • 本题探讨在特定条件下如何通过选择瓶子以最大化从火星人处获取的燃料量。 ... [详细]
  • 本文介绍了如何使用JFreeChart库创建一个美观且功能丰富的环形图。通过设置主题、字体和颜色等属性,可以生成符合特定需求的图表。 ... [详细]
  • 本文探讨了如何使用pg-promise库在PostgreSQL中高效地批量插入多条记录,包括通过事务和单一查询两种方法。 ... [详细]
  • 本文详细介绍了Linux内核中misc设备驱动框架的实现原理及应用方法,包括misc设备的基本概念、驱动框架的初始化过程、数据结构分析以及设备的注册与注销流程。 ... [详细]
  • QNX 微内核(procnto-instr)的监测版本内置了高级跟踪与分析工具,能够实现实时系统监控。该模块适用于单处理器及多处理器系统。 ... [详细]
  • 1、字符型常量字符型常量指单个字符,是用一对单引号及其所括起来的字符表示。例如:‘A’、‘a’、‘0’、’$‘等都是字符型常量。C语言的字符使用的就是 ... [详细]
  • 在Java应用程序开发过程中,FTP协议被广泛用于文件的上传和下载操作。本文通过Jakarta Commons Net库中的FTPClient类,详细介绍如何实现文件的上传和下载功能。 ... [详细]
  • 本文探讨了在QT框架中如何有效遍历文件内容,并解决了一个常见的错误,即文件内容读取为空时弹窗无法正常显示的问题。 ... [详细]
  • iOS 开发技巧:TabBarController 自定义与本地通知设置
    本文介绍了如何在 iOS 中自定义 TabBarController 的背景颜色和选中项的颜色,以及如何使用本地通知设置应用程序图标上的提醒个数。通过这些技巧,可以提升应用的用户体验。 ... [详细]
  • 近期我们开发了一款包含天气预报功能的万年历应用,为了满足这一需求,团队花费数日时间精心打造并测试了一个稳定可靠的天气API接口,现正式对外开放。 ... [详细]
  • KMP算法是一种高效的字符串模式匹配算法,能够在不进行回溯的情况下完成匹配,其时间复杂度为O(m+n),其中m和n分别为文本串和模式串的长度。本文将详细介绍KMP算法的工作原理,并提供C语言实现。 ... [详细]
  • 本文详细解析了2019年西安邀请赛中的一道树形动态规划题目——J题《And And And》。题目要求计算树中所有子路径异或值为0的集合数量,通过深入分析和算法优化,提供了高效的解决方案。 ... [详细]
  • 本文介绍了如何利用Java中的URLConnection类来实现基本的网络爬虫功能,包括向目标网站发送请求、接收HTML响应、解析HTML以提取所需信息,并处理可能存在的递归爬取需求。 ... [详细]
  • 本文介绍了如何通过ARM编译器组件重定向标准C运行时库的I/O函数,以适应不同的硬件平台。原文链接:https://www.keil.com/pack/doc/compiler/RetargetIO/html/retarget_overview.html ... [详细]
  • YB02 防水车载GPS追踪器
    YB02防水车载GPS追踪器由Yuebiz科技有限公司设计生产,适用于车辆防盗、车队管理和实时追踪等多种场合。 ... [详细]
author-avatar
往事如烟zhang_214
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有