『代码』··By/蜜汁炒酸奶

operator重载之矩阵的运算—C++

/*
功能:矩阵的运算
作者:wind
日期:2013-11-29
*/
#include <iostream>
#include <string>
using namespace std;
/************************************************************/
class Reckle
{
public:
	Reckle()
	{
		m_iA = 0;
		m_iB = 0;
		m_iC = 0;
		m_iD = 0;
	}
	void set(double aA,double aB,double aC,double aD);
	void get()const;
	Reckle operator + (Reckle c1);
	Reckle operator - (Reckle c1);
	void display(Reckle c1);
private:
	double m_iA;
	double m_iB;
	double m_iC;
	double m_iD;
};
/************************************************************/
void Reckle::set(double aA,double aB,double aC,double aD)
{
	m_iA = aA;
	m_iB = aB;
	m_iC = aC;
	m_iD = aD;
}
void Reckle::get()const
{
	cout<<"The result is:"<<endl;
	cout<<"("<<m_iA<<","<<m_iB<<")"<<endl;
	cout<<"("<<m_iC<<","<<m_iD<<")"<<endl;
}
Reckle Reckle::operator + (Reckle c1)
{
    Reckle c;
	c.m_iA = m_iA + c1.m_iA;
	c.m_iB = m_iB + c1.m_iB;
	c.m_iC = m_iC + c1.m_iC;
	c.m_iD = m_iD + c1.m_iD;
	return c;
}
Reckle Reckle::operator - (Reckle c1)
{
	Reckle c;
	c.m_iA = m_iA - c1.m_iA;
	c.m_iB = m_iB - c1.m_iB;
	c.m_iC = m_iC - c1.m_iC;
	c.m_iD = m_iD - c1.m_iD;
	return c;
}

void Reckle::display(Reckle c1)
{
	string n;
	Reckle c;
	cout<<"Please input the sign(-/+):";
	cin>>n;
	if  ("-" == n)
	{
		c = operator- (c1);
		cout<<"The result is:"<<endl;
		cout<<"("<<c.m_iA<<","<<c.m_iB<<")"<<endl;
		cout<<"("<<c.m_iC<<","<<c.m_iD<<")"<<endl;
	}
	else if ("+" == n)
	{
		c = operator+ (c1);
		cout<<"The result is:"<<endl;
		cout<<"("<<c.m_iA<<","<<c.m_iB<<")"<<endl;
		cout<<"("<<c.m_iC<<","<<c.m_iD<<")"<<endl;
	}
	else
	{
		cout<<"The operator is error";
	}
}
/************************************************************/
int main(void)
{

	Reckle c1,c2;
	double x = 0;
	double y = 0;
	double z = 0;
	double h = 0;

	cout<<"请输入第一个矩阵(两行两列):"<<endl;
	cin>>x>>y>>z>>h;
	c1.set(x,y,z,h);

	cout<<"请输入第二个矩阵(两行两列):"<<endl;
	cin>>x>>y>>z>>h;
	c2.set(x,y,z,h);

    c1.display(c2);
	system("pause");
	return 0;
}
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

预览
Loading comments...
0 条评论

暂无数据

example
预览