编写一个程序,设计一个类Trig,给定三角形的三边长x、y、z,包含一个友元函数计算两个三角形面积之和
#include
#include
using namespace std;
class Trig
{
public:
float s(float x,float y,float z);
Trig(float x,float y,float z);
friend float add(Trig &s1,Trig &s2);
private:
float a,b,c;
};
float Trig::s(float x,float y,float z){
float l;
l=0.5*(x+y+z);
return sqrt(l*(l-x)*(l-y)*(l-z));
}
Trig::Trig(float x,float y,float z){
a=x;
b=y;
c=z;
}
float add(Trig &t1,Trig &t2)
{
float x1=t1.s(x,y,z);
float x2=t2.s(x,y,z);
return x1+x2;
}
int main()
{
float x1,y1,z1;
float x2,y2,z2;
cout<<"输入第一个三角形的三边长"<
cin>>x1>>y1>>z1;
cout<<"输入第二个三角形的三边长"<
cin>>x2>>y2>>z2;
Trig triangle1(x1,y1,z1);
Trig triangle2(x2,y2,z2);
cout<<triangle1.s(x1,y1,z1)<<" "<<triangle2.s(x2,y2,z2)<<endl;
return 0;
}
求解怎么利用友元函数计算两个三角形的面积和,我这么做对吗?