博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分数的表示以及计算(c++)
阅读量:6159 次
发布时间:2019-06-21

本文共 1724 字,大约阅读时间需要 5 分钟。

之前一直总是简单的想将分数化为小数进行计算,其实使用相应的结构进行分子分母的分开保存,可以有奇效;

分数的存储:

struct Fraction{    int up;    int down;};

其中up代表分子,down代表分母;

对于分数,有基本的几个规则:

1.正负号挂在分子上;
2.当分数表示0的时候,分子为0,分母为1;
3.分子分母必须达到最简,也就是没有1以外的公约数

当分数进行四则运算的时候,也是基于这三条的性质来进行化简;

Fraction reduction(Fraction result){    if(result.down<0){        result.up=-result.up;        result.down=-result.down;    }    if(result.up==0){        result.down=1;    }else{        int d=gcd(abs(result.up),abs(result.down));        result.up/=d;        result.down/=d;    }    return result;}

其中值得注意的是进行最大公约数计算的时候一定要注意注意分子可能为负,所以要进行绝对值的提前处理;

分数的四则运算:

在上述化简函数的基础上,我们就可以根据该规则进行相应的四则运算,四则运算严格遵循计算的通分规律;
1.加法运算:

Fraction add(Fraction f1,Fraction f2){    Fraction result;    result.up=f1.up*f2.down+f2.up*f1.down;    result.down=f1.down*f2.down;    return reduction(result);}

2.减法运算:

Fraction minu(Fraction f1,Fraction f2){    Fraction result;    result.up=f1.up*f2.down-f1.down*f2.up;    result.down=f1.down*f2.down;    return reduction(result);}

3.乘法运算

Fraction multi(Fraction f1,Fraction f2){    Fraction result;    result.up=f1.up*f2.up;    result.down=f2.down*f2.down;    return reduction(result);}

4.除法运算:

Fraction divide(Fraction f1,Fraction f2){    Fraction result;    result.up=f1.up*f2.down;    result.down=f2.up*f2.down;    return reduction(result);}

值得注意的是这里采用的除法的倒数计算;

分数的输出形式:

对于一个正常形式的分数,往往有三种形式:
1.整数:此时只输出分子(由于程序代码里对分子分母进行化简,所以如果有整数分母一定为1);
2.真分数:此时按照a/b的格式输出;
3.假分数:此时应该在按照带分数的格式输出,并且符号在前;

代码如下:

void showResult(Fraction r){    r=reduction(r);    if(r.down==1)        printf("%lld",r.up);    else if(abs(r.up)>r.down){        printf("%d %d/%d",r.up/r.down,abs(r.up)%r.down,r.down);    }else{        printf("%d/%d",r.up,r.down);    }}

值得注意的是当进行带分数计算的时候,计算其后真分数余数的时候,一定要注意abs绝对值得处理;

转载地址:http://qjsfa.baihongyu.com/

你可能感兴趣的文章
eclipse的maven、Scala环境搭建
查看>>
架构师之路(一)- 什么是软件架构
查看>>
USACO 土地购买
查看>>
【原创】远景能源面试--一面
查看>>
B1010.一元多项式求导(25)
查看>>
10、程序员和编译器之间的关系
查看>>
配置 RAILS FOR JRUBY1.7.4
查看>>
AndroidStudio中导入SlidingMenu报错解决方案
查看>>
修改GRUB2背景图片
查看>>
Ajax异步
查看>>
好记性不如烂笔杆-android学习笔记<十六> switcher和gallery
查看>>
JAVA GC
查看>>
3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)
查看>>
图解SSH原理及两种登录方法
查看>>
【总结整理】JQuery基础学习---样式篇
查看>>
查询个人站点的文章、分类和标签查询
查看>>
基础知识:数字、字符串、列表 的类型及内置方法
查看>>
JSP的隐式对象
查看>>
JS图片跟着鼠标跑效果
查看>>
[SCOI2005][BZOJ 1084]最大子矩阵
查看>>