前言:本期是关于有理数加法的具体解法,今天你c了吗?

​​​​​​​

题目:

本题要求编写程序,计算两个有理数的和。

输入格式:

输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

输出格式:

在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

1/3 1/6

输出样例1:

1/2

输入样例2:

4/3 2/3

输出样例2:

2

代码实现: 

#include <stdio.h>
int main()
{int a1=0;int b1=0;int a2=0;int b2=0;scanf("%d/%d %d/%d",&a1,&b1,&a2,&b2);int ret1=0;int ret2=0;int tmp=0;ret1=a1*b2+a2*b1;ret2=b1*b2;int a=ret1;int b=ret2;while(tmp=ret2%ret1){ret2=ret1;ret1=tmp;}int max=ret1;a/=max;b/=max;if(a%b==0){printf("%d",a);}else{printf("%d/%d",a,b);}return 0;
}

大致思路: 

1.分别求出两个分数相加后的结果的未化简的分子和分母

2.求出这分子和这分母的最大公约数,化简分子和分母


代码解读:

part 1

    int a1=0;int b1=0;int a2=0;int b2=0;scanf("%d/%d %d/%d",&a1,&b1,&a2,&b2);int ret1=0;int ret2=0;ret1=a1*b2+a2*b1;ret2=b1*b2;

1.读取两个分数的分子和分母:a1,b1,a2,b2

2.算出分子和的分子存入ret1中,其分母存入ret2中


part 2

    int tmp=0;int a=ret1;int b=ret2;while(tmp=ret2%ret1){ret2=ret1;ret1=tmp;}int max=ret1;a/=max;b/=max;

1.辗转相除法求出要化简的分子和分母的最大公约数存入max中

2. 注意:直接使用分子分母进行辗转相除法,会改变分子分母的大小,这里使用同时定义a存储分子ret1的值,定义b存储分母ret2的值

3.求出最大公约数max后,化简分子分母


part 3 

    if(a%b==0){printf("%d",a);}else{printf("%d/%d",a,b);}

满足题目要求:若是分母为1则只输出分子

本期完!

PTA 7-33 有理数加法(详解)相关推荐

  1. PTA L1-006 连续因子(详解)

    前言:本期是关于pta题目:连续因子的详解,今天你c了吗? 题目:  一个正整数 N 的因子中可能存在若干连续的数字.例如 630 可以分解为 3×5×6×7,其中 5.6.7 就是 3 个连续的数字 ...

  2. python之33个关键字详解_Python解析、提取url关键字的实例详解

    解析url用的类库: python2版本: from urlparse import urlparse import urllib python3版本: from urllib.parse impor ...

  3. PTA L1-003 个位数统计(详解)

    前言:本期是关于pta题目:个位数统计的详细解法,今天你c了吗? 题目:  给定一个 k 位整数 N=dk−1​10k−1+⋯+d1​101+d0​ (0≤di​≤9, i=0,⋯,k−1, dk−1 ...

  4. 一元多项式的加法详解

    一元多项式的加法(c语言版) 我是观看懒猫老师的视频后写的,大家有不懂的可以在评论区留言或者去某站看懒猫老师的视频 代码如下: #include<stdio.h> #include< ...

  5. PTA 7-36 复数四则运算(详解)

    前言:本期是关于复数四则运算的具体解法,今天你c了吗? 题目: 本题要求编写程序,计算2个复数的和.差.积.商. 输入格式: 输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i ...

  6. 高精度计算--高精度加法详解

    文章目录 前言 一.高精度加法分析 1.1 数学的竖式加法计算 1.2 数组模拟竖式计算 1.3 计算步骤分析 二.使用步骤 2.1 代码结构 2.2 读入数据并倒置:readDataAndRever ...

  7. 位运算 加法详解

    位运算操作基础 符号 描述 运算规则 & 位与运算 两个位都为1时,结果才为1 | 位或运算 两个位都为0时,结果才为0 ^ 异或运算 两个位相同为0,相异为1 ~ 取反运算 0变1,1变0 ...

  8. PTA L1-002 打印沙漏(详解)

    前言:本期是关于pta题目打印沙漏的具体解法,今天你c了吗?  题目: 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个"*",要求按下列格式打印 ********* ...

  9. 33 张图详解 RSTP 、MSTP、替代技术

    10 秒看完文章主要内容,试试你有多快. STP 的弊端 上次有写过一篇<图解 STP >的文章,里面有提到 STP 的功能是消除环路和链路备份,同时也发现 STP 的一些问题: 网络收敛 ...

  10. python之33个关键字详解_Python 中的关键字 with 详解

    在 Python 2.5 中,with关键字被加入.它将常用的 try ... except ... finally ...模式很方便的被复用.看一个最经典的例子: with open('file.t ...

最新文章

  1. aop切面排除某个类_AOP 你看这一篇就够了
  2. 阿里智能运维平台如何助力研发应对双11挑战
  3. 构造activeMQ
  4. 流畅的python 数据模型
  5. 帆软报表-打印sql日志设置
  6. 贺利坚老师汇编课程36笔记:[BX+SI+IDATA]和[BX+DI+IDATA]寻址
  7. Linux抓包命令集锦(tcpdump抓包)
  8. 如何免费使用xshell、xftp工具
  9. Spring Security(14)——权限鉴定基础
  10. 如何用html写抖动效果,利用transition实现文字上下抖动的效果
  11. 【报告分享】2021国民健康洞察报告-丁香(附下载)
  12. 5.8日 ksjsb 小黄鸟抓快手ck教程
  13. 简单实用,聊聊我常用的 4 款 Pandas 自动数据分析神器
  14. Linux Shell重定向 管道命令 grep搜索 awk编程 sed文件操作高阶函数
  15. core dump磁盘报警问题排查过程
  16. 计算机英语教案模板,小学英语教案模板三篇
  17. [转]做个男人,做个成熟的男人,做个有城府的男人
  18. 初学CAD,该如何正确查看CAD图纸呢?
  19. 关于MySQL修改密码
  20. 爱拼t6输入法 v3.10 完整版 免费下载

热门文章

  1. java怎么打印星期,在任何日期打印出星期几
  2. 100个中国传统英文词汇,你会用英语表达吗?
  3. SCI论文写作--IEEE期刊的Word模板(LaTeX也有)
  4. Efforts should be valuable
  5. 616 给字符串添加加粗标签
  6. 关于4A统一安全管理平台解决方案简单介绍
  7. java net unicode / native2ascii / url decode / url encode / UTF8 / js url code
  8. 关于云计算必知的关键核心技术
  9. PHP5中调用Java类
  10. SQL注入与万能密码登录