
一道简单的c++编程题?
按下面的要求编程并调试:编写一类Cpoint表示一个点的信息。在此基础上编写一个表示三角形的类tria,顶点为其对象成员。编写完整的程序输出三角形的面积。(带注释说明)答...
按下面的要求编程并调试:
编写一类Cpoint 表示一个点的信息。在此基础上编写一个表示三角形的类tria,顶点为其对象成员。编写完整的程序输出三角形的面积。(带注释说明)
答得好一定加分!!!!!
二维的 展开
编写一类Cpoint 表示一个点的信息。在此基础上编写一个表示三角形的类tria,顶点为其对象成员。编写完整的程序输出三角形的面积。(带注释说明)
答得好一定加分!!!!!
二维的 展开
展开全部
知道三条边求面积,高中时候的数学应该学过
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不知道你是要三维的还是二维的
一点提示:
三角形的面积等于三角形任意两边向量叉乘所得成绩的一半 有关叉乘你应该自己查资料了吧
#include <math.h>
#include<iostream>
using namespace std;
class Cpoint
{
public:
Cpoint()
{
x=y=0;
}
Cpoint(double x0, double y0):x(x0), y(y0)
{
}
double getx();
double gety();
private:
double x,
y;
};
double Cpoint::getx()
{
return x;
}
double Cpoint::gety()
{
return y;
}
class tria
{
public:
tria():a(),b(),c(),S(0)
{}
tria(double x0,double y0,double x1,double y1,
double x2,double y2):a(x0,y0),b(x1,y1),c(x2,y2)
{
S=fabs(((x1-x0)*(y2-y0)-(x2-x0)*(y1-y0))/2);
}
double getS();
void seta(double,double);
void setb(double,double);
void setc(double,double);
private:
Cpoint a,b,c;
double S;
};
void tria::seta(double x0,double y0)
{
a=Cpoint(x0,y0);
}
void tria::setb(double x0,double y0)
{
b=Cpoint(x0,y0);
}
void tria::setc(double x0,double y0)
{
c=Cpoint(x0,y0);
}
double tria::getS()
{
if(S==0)
{
S=fabs(((b.getx()-a.getx())*(c.gety()-a.gety())-
(c.getx()-a.getx())*(b.gety()-a.gety()))/2);
}
return S;
}
int main()
{
tria triangle(0,0,0,3,4,0);
cout<<triangle.getS()<<endl;
tria trgle;
trgle.seta(0,0);
trgle.setb(0,3);
trgle.setc(4,0);
cout<<trgle.getS()<<endl;
return 0;
}
一点提示:
三角形的面积等于三角形任意两边向量叉乘所得成绩的一半 有关叉乘你应该自己查资料了吧
#include <math.h>
#include<iostream>
using namespace std;
class Cpoint
{
public:
Cpoint()
{
x=y=0;
}
Cpoint(double x0, double y0):x(x0), y(y0)
{
}
double getx();
double gety();
private:
double x,
y;
};
double Cpoint::getx()
{
return x;
}
double Cpoint::gety()
{
return y;
}
class tria
{
public:
tria():a(),b(),c(),S(0)
{}
tria(double x0,double y0,double x1,double y1,
double x2,double y2):a(x0,y0),b(x1,y1),c(x2,y2)
{
S=fabs(((x1-x0)*(y2-y0)-(x2-x0)*(y1-y0))/2);
}
double getS();
void seta(double,double);
void setb(double,double);
void setc(double,double);
private:
Cpoint a,b,c;
double S;
};
void tria::seta(double x0,double y0)
{
a=Cpoint(x0,y0);
}
void tria::setb(double x0,double y0)
{
b=Cpoint(x0,y0);
}
void tria::setc(double x0,double y0)
{
c=Cpoint(x0,y0);
}
double tria::getS()
{
if(S==0)
{
S=fabs(((b.getx()-a.getx())*(c.gety()-a.gety())-
(c.getx()-a.getx())*(b.gety()-a.gety()))/2);
}
return S;
}
int main()
{
tria triangle(0,0,0,3,4,0);
cout<<triangle.getS()<<endl;
tria trgle;
trgle.seta(0,0);
trgle.setb(0,3);
trgle.setc(4,0);
cout<<trgle.getS()<<endl;
return 0;
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询