求两个分数的加减乘除,并比较大小

2024-04-08 05:08

本文主要是介绍求两个分数的加减乘除,并比较大小,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//初始化分子分母
-(instancetype)initWithFz:(NSInteger)fz andFm:(NSInteger)fm{if (self = [super init]) {_fz = fz;_fm = fm;}return self;}//便利构造器
+(instancetype)initWithFz:(NSInteger)fz andFm:(NSInteger)fm{Fraction * f = [[Fraction alloc]initWithFz:fz andFm:fm];return f;
}//最大公约数
-(NSInteger)maxDivisor:(NSInteger)num1 : (NSInteger)num2{if (num1 * num2 == 0) {return 0;}else{NSInteger max = (num1>num2) ? num1 : num2;NSInteger min = (num1<num2) ? num1 : num2;NSInteger rem = 1;while (rem != 0) {rem = max % min;max = min;min = rem;}return max;}
}//约分
-(void)reduceFraction{NSInteger greatCommonDivisor = [self maxDivisor:_fz :_fm];if (greatCommonDivisor == 0) {return;}else{_fz/=greatCommonDivisor;_fm/=greatCommonDivisor;}
}//相加
-(Fraction *)addFraction:(Fraction *)frac{Fraction * f = [[Fraction alloc]init];f.fz = _fz * frac.fm + _fm * frac.fz;f.fm = _fm * frac.fm;[f reduceFraction];return f;
}//相减
-(Fraction *)subFraction:(Fraction *)frac{Fraction * f = [[Fraction alloc]init];f.fz = _fz * frac.fm - _fm * frac.fz;f.fm = _fm * frac.fm;[f reduceFraction];return f;
}//相乘
-(Fraction *)mulFraction:(Fraction *)frac{Fraction * f = [[Fraction alloc]init];f.fz = _fz * frac.fz;f.fm = _fm * frac.fm;[f reduceFraction];return f;
}//相除
-(Fraction *)divFraction:(Fraction *)frac{Fraction * f = [[Fraction alloc]init];f.fz = _fz * frac.fm;f.fm = _fm * frac.fz;[f reduceFraction];return f;
}//比较大小
-(Fraction *)maxValue:(Fraction *)frac{Fraction * f = [[Fraction alloc]init];_fz = _fz * frac.fm;frac.fz = _fm * frac.fz;f.fz = ( _fz > frac.fz ? _fz : frac.fz);f.fm = _fm * frac.fm;[f reduceFraction];return f;
}//打印分数
-(void)printFraction{if (_fz * _fm >= 0) {NSLog(@"两分数运算结果为:%ld/%ld",_fz,_fm);}else{NSLog(@"两分数运算结果为:-%ld/%ld",labs(_fz),labs(_fm));}
}


这篇关于求两个分数的加减乘除,并比较大小的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/884646

相关文章

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

关键字synchronized、volatile的比较

关键字volatile是线程同步的轻量级实现,所以volatile性能肯定比synchronized要好,并且volatile只能修饰于变量,而synchronized可以修饰方法,以及代码块。随着JDK新版本的发布,synchronized关键字的执行效率上得到很大提升,在开发中使用synchronized关键字的比率还是比较大的。多线程访问volatile不会发生阻塞,而synchronize

PDFQFZ高效定制:印章位置、大小随心所欲

前言 在科技编织的快节奏时代,我们不仅追求速度,更追求质量,让每一分努力都转化为生活的甜蜜果实——正是在这样的背景下,一款名为PDFQFZ-PDF的实用软件应运而生,它以其独特的功能和高效的处理能力,在PDF文档处理领域脱颖而出。 它的开发,源自于对现代办公效率提升的迫切需求。在数字化办公日益普及的今天,PDF作为一种跨平台、不易被篡改的文档格式,被广泛应用于合同签署、报告提交、证书打印等各个

2024年AMC10美国数学竞赛倒计时两个月:吃透1250道真题和知识点(持续)

根据通知,2024年AMC10美国数学竞赛的报名还有两周,正式比赛还有两个月就要开始了。计划参赛的孩子们要记好时间,认真备考,最后冲刺再提高成绩。 那么如何备考2024年AMC10美国数学竞赛呢?做真题,吃透真题和背后的知识点是备考AMC8、AMC10有效的方法之一。通过做真题,可以帮助孩子找到真实竞赛的感觉,而且更加贴近比赛的内容,可以通过真题查漏补缺,更有针对性的补齐知识的短板。

【CSS in Depth 2 精译_024】4.2 弹性子元素的大小

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一章 层叠、优先级与继承(已完结) 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位(已完结) 2.1 相对单位的威力2.2 em 与 rem2.3 告别像素思维2.4 视口的相对单位2.5 无单位的数值与行高2.6 自定义属性2.7 本章小结 第三章 文档流与盒模型(已