- 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的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
假设我有一个类,我在其中重载了运算符 == : Class A { ... public: bool operator== (const A &rhs) const; ... };
我知道你不应该使用 std::find(some_map.begin(), some_map.end()) 或 std::lower_bound,因为它会采用线性时间而不是 some_map.lowe
我正在尝试在 Haskell 中定义 Vector3 数据类型,并允许在其上使用 (+) 运算符。我尝试了以下方法: data Vector3 = Vector3 Double Double Doub
我已经为我的类图将运算符重载为“-”。它的用途并不完全直观(糟糕的编码 - 我知道)但是如果我做 graph3 = graph2-graph1 那么图 3 是应该只接收图 2 和图 1 中的那些顶点。
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Operator overloading 我想重载 以按字母顺序排列字符串,但我不确定该怎么做。 如何再次
下面的代码给我一个编译错误。谁能告诉我为什么? class mytype { public: int value; mytype(int a) { value = a;
这有什么问题吗? class Vec2 attr_accessor :x, :y # ... def += (v) @x += v.x @y += v.y retu
是否可以重载 [] 运算符两次?允许这样的事情:function[3][3](就像在二维数组中一样)。 如果可能的话,我想看看一些示例代码。 最佳答案 您可以重载 operator[] 以返回一个对象
我的团队目前正在与 Lua 合作,创建一个 android 游戏。我们遇到的一件事是表面上无法创建重载构造函数。 我习惯于使用默认值设置一个对象,然后在需要时使其过载。 前任: apples() {
我有一个网页,在某个时候显示一个导航栏,它只不过是一个 a 元素的列表 (ul)。所述 a 元素的大多数样式规则都是通用的。唯一应该改变的部分是要显示的图像,可以从列表中每个 li 元素的 id 标签
我对使用/重载“范围步长”运算符(.. ..)很感兴趣,但我终其一生都无法了解如何使用它。 在文档中它说 // Usage: start .. step .. finish 但是在 F# shell
Java 11(可能无关紧要): public static String toString(Object obj) { return ReflectionToStringBuilder.to
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我无法理解以下代码(针对行号进行注释) class Base { void m1(Object o) { } void m2(String o) { } } publi
我有以下代码片段: #include using namespace std; struct Integer{ int x; Integer(const int val) : x(v
class myclass{ //definitions here }; myclass e; int myarray[10]; /* Do something... */ e = myarray;
为什么不能将下标运算符(operator [])作为 friend 函数重载? 最佳答案 正如Bjarne Stroustrup在D&E book中所说: However, even in the o
我有以下代码片段: #include using namespace std; struct Integer{ int x; Integer(const int val) : x(v
因此,我有一个问题是我最近尝试重载 namespace Eng { /** * A structure to represent pixels */ typedef
如何重载onResume()以正确的方式工作?我想从 activity 返回到 MainActivity ,我希望在其中具有与应用程序启动后相同的状态。我想使用 recreate() 但它循环了或者类
我是一名优秀的程序员,十分优秀!