面向对象程序设计上机练习十一(运算符重载)
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
有两个矩阵a和b,均为2行3列,求两个矩阵之和。重载运算符“+”,使之能用于矩阵相加。如:c=a+b。
Input
第1、2行是矩阵a的值,数据以空格分开。
第3、4行是矩阵b的值,数据以空格分开。
第3、4行是矩阵b的值,数据以空格分开。
Output
2个矩阵a、b之和,以行列形式显示。
Example Input
2 3 4 3 5 3 4 3 1 5 4 3
Example Output
6 6 5 8 9 6
Hint
Author
zlh
#include<bits/stdc++.h>
using namespace std;
class A
{
public:
A(int a = 0, int b = 0, int c = 0, int d = 0, int e = 0, int f = 0)
{
x1 = a; y1 = b; z1 = c;
x2 = d; y2 = e; z2 = f;
}
A operator+(A&p1);
friend ostream&operator<<(ostream&output,A&p1);
private:
int x1, y1, z1;
int x2, y2, z2;
};
A A::operator+(A&p1)
{
A p;
p.x1 = x1 + p1.x1;
p.y1 = y1 + p1.y1;
p.z1 = z1 + p1.z1;
p.x2 = x2 + p1.x2;
p.y2 = y2 + p1.y2;
p.z2 = z2 + p1.z2;
return p;
}
ostream&operator<<(ostream&output,A&p1)
{
output<<p1.x1<<' '<<p1.y1<<' '<<p1.z1<<endl;
output<<p1.x2<<' '<<p1.y2<<' '<<p1.z2<<endl;
return output;
}
int main()
{
int a, b, c, d, e, f;
cin>>a>>b>>c>>d>>e>>f;
A p1(a,b,c,d,e,f);
cin>>a>>b>>c>>d>>e>>f;
A p2(a,b,c,d,e,f);
A p3;
p3 = p1 + p2;
cout<<p3;
return 0;
}
using namespace std;
class A
{
public:
A(int a = 0, int b = 0, int c = 0, int d = 0, int e = 0, int f = 0)
{
x1 = a; y1 = b; z1 = c;
x2 = d; y2 = e; z2 = f;
}
A operator+(A&p1);
friend ostream&operator<<(ostream&output,A&p1);
private:
int x1, y1, z1;
int x2, y2, z2;
};
A A::operator+(A&p1)
{
A p;
p.x1 = x1 + p1.x1;
p.y1 = y1 + p1.y1;
p.z1 = z1 + p1.z1;
p.x2 = x2 + p1.x2;
p.y2 = y2 + p1.y2;
p.z2 = z2 + p1.z2;
return p;
}
ostream&operator<<(ostream&output,A&p1)
{
output<<p1.x1<<' '<<p1.y1<<' '<<p1.z1<<endl;
output<<p1.x2<<' '<<p1.y2<<' '<<p1.z2<<endl;
return output;
}
int main()
{
int a, b, c, d, e, f;
cin>>a>>b>>c>>d>>e>>f;
A p1(a,b,c,d,e,f);
cin>>a>>b>>c>>d>>e>>f;
A p2(a,b,c,d,e,f);
A p3;
p3 = p1 + p2;
cout<<p3;
return 0;
}