您的位置:首页 > 其它

第五周上机实践项目——项目1-三角形类雏形-(5)

2016-03-26 12:30 337 查看
/*
*Copyright (c)2016,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:main.cpp
*作    者:郭永恒
*完成日期:2016年3月26日
*版 本 号:v1.0
*
*问题描述: 使用复制构造函数
*/

#include <iostream>
#include <cmath>
using namespace std;

class Triangle
{
public:
Triangle(double x = 1.0, double y = 1.0, double z = 1.0): a(x),b(y),c(z) {}//构造函数
Triangle(const Triangle &t):a(t.a),b(t.b),c(t.c){}//复制构造函数

void setABC(double x, double y, double z);
double perimeter();//计算三角形周长
double area();//计算三角形面积
void setA(double x) {a = x;}
void setB(double y) {b = y;}
void setC(double z) {c = z;}
double getA() {return a;}
double getB() {return b;}
double getC() {return c;}
void showMessage();//显示三角形的信息
bool isTriangle()
{
if(a+b > c && a+c > b && b+c > a)
return true;
else
return false;
}
private:
double a,b,c;
};

void Triangle::showMessage()
{
if(isTriangle())
{
cout << "三条边为:" << a << "," << b << "," << c << endl;
cout << "三角形的周长为:" << perimeter() << "\t" << "面积为:" << area() << endl;
}
else
cout << "不能构成三角形" << endl;
}

void Triangle::setABC(double x, double y, double z)
{
a = x;
b = y;
c = z;
}

double Triangle::perimeter()
{
return a+b+c;
}

double Triangle::area()
{
double p = (a+b+c)/2;
return sqrt(p*(p-a)*(p-b)*(p-c));
};

int main()
{
Triangle Tri1(3,4,5);
Tri1.showMessage();

Triangle Tri2(Tri1);
Tri2.showMessage();

return 0;
}

运行结果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: