- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章C++重载运算符实现分数加减乘除由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例为大家分享了C++重载运算符实现分数加减乘除的具体代码,供大家参考,具体内容如下 。
实现结果如下图所示:
代码如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
#include <iostream>
using
namespace
std;
class
Rational {
public
:
Rational operator+(Rational rhs);
Rational operator-(Rational rhs);
Rational operator*(Rational rhs);
Rational operator/(Rational rhs);
Rational(
int
num,
int
denom);
private
:
void
normalize();
//负责对分数做化简工作
int
numerator;
//分子
int
denominator;
//分母
friend
std::ostream& operator<<(ostream& os, Rational f);
};
Rational::Rational(
int
num,
int
denom) {
numerator = num;
denominator = denom;
normalize();
}
//只允许分子为负数,若分母为负数则把负数挪到分子部分
//利用欧几里得算法将分数简化
void
Rational::normalize() {
if
(denominator < 0) {
numerator = -numerator;
denominator = -denominator;
}
//欧几里得算法
int
a =
abs
(numerator);
int
b =
abs
(denominator);
//求出最大公约数,a
//eg: a=12,b=9.
//t=3 a=9 b=3
//t=0 a=3 b=0
while
(b > 0) {
int
t = a % b;
//t为余数
a = b;
//a取除数
b = t;
//b取余数
}
//分子、分母分别处以最大公约数
numerator /= a;
denominator /= a;
}
//重载运算符函数是类的成员函数
//分数是先通分再加减
// a*d+b*c / b*d
Rational Rational::operator+(Rational rhs) {
int
a = numerator;
int
b = denominator;
int
c = rhs.numerator;
int
d = rhs.denominator;
return
Rational(a*d+b*c,b*d);
}
Rational Rational::operator-(Rational rhs) {
int
a = numerator;
int
b = denominator;
int
c = rhs.numerator;
int
d = rhs.denominator;
return
Rational(a*d - b*c, b*d);
/*
**这里有个偷懒的写法
rhs.numerator = -rhs.numerator;
return operator+(rhs);
*/
}
Rational Rational::operator*(Rational rhs) {
int
a = numerator;
int
b = denominator;
int
c = rhs.numerator;
int
d = rhs.denominator;
return
Rational(a*c, b*d);
}
Rational Rational::operator/(Rational rhs) {
int
t = rhs.denominator;
rhs.denominator = rhs.numerator;
rhs.numerator = t;
return
operator*(rhs);
}
//该函数是友元函数,因此不用加空间域名
ostream& operator<<(ostream& os, Rational f);
int
main() {
Rational r1(4, 18);
Rational r2(14, 18);
cout << r1 <<
" + "
<< r2 <<
" = "
<< (r1 + r2) << endl;
cout << r1 <<
" - "
<< r2 <<
" = "
<< (r1 - r2) << endl;
cout << r1 <<
" * "
<< r2 <<
" = "
<< (r1 * r2) << endl;
cout << r1 <<
" / "
<< r2 <<
" = "
<< (r1 / r2) << endl;
system
(
"pause"
);
return
0;
}
ostream& operator<<(ostream& os, Rational f) {
os << f.numerator <<
"/"
<< f.denominator;
return
os;
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/Quellaaa/article/details/80177341 。
最后此篇关于C++重载运算符实现分数加减乘除的文章就讲到这里了,如果你想了解更多关于C++重载运算符实现分数加减乘除的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我需要帮助返回表达式的值(表达式是函数的参数)。 这是我目前尝试过的。这只是一个随机方程的例子,我的计划是了解如何正确求解它,以便稍后将其转换为函数 sum = 0 eq = '2+4-5' stri
您好,我正在尝试计算按键时一行中多个字段的总和(我的代码将包含多行)(其中一些使用加法,一些使用减法)但由于我是新手,我对 JQuery 不太熟悉。在我的场景中,B.Salary、Rec.comm、S
所以它应该做的是能够接收一个 const char* str 并将其更改为一个 int,然后将其转换回一个字符串以供输出。但它也应该能够将这些加减在一起。我正在通过我的前两个测试,但我的添加发生了一些
这个问题在这里已经有了答案: Retain precision with double in Java (24 个回答) 关闭9年前。 所以当我在 Java 中使用 Doubles 进行加法或减法时,
Java 的开发过程中免不了与 Date 类型纠缠,准备总结一下项目经常使用的日期相关操作,JDK 版本 1.7,如果能够帮助大家节约那么几分钟起身活动一下,去泡杯咖啡,便是极好的,嘿嘿。当然,我
我将用户提供的 html 保存在数据库中,“指定或不指定”css 字体大小。 并尝试制作一个按钮来放大或减小 dom 上的字体大小,但保持相对大小。 我将变量 def_size 定义为 16px,并将
我有一个看起来很容易解决的问题,但是我不确定语法。 我需要运行 if/else 语句,但我不确定如何正确设置条件。 错误代码: if (float_a = float_b or is within +
刚开始学习 C#。我计划将它用于繁重的数学模拟,包括数值求解。问题是我在加减 double 以及进行比较时会出现精度损失。代码及其返回的内容(在注释中)如下: namespace ex3 {
我是一名优秀的程序员,十分优秀!