01./*
02.* 程序的版权和版本声明部分
03.* Copyright (c)2013, 烟台大学计算机学院学生
04.* All rightsreserved.
05.* 文件名称: Triangle.cpp
06.* 作 者:赵冠哲
07.* 完成日期:2013年3月22日
08.* 版本号: v1.0
09.* 输入描述:
10.* 问题描述:
11.*/
#include<iostream>
#include<Cmath>
using namespace std;
class Triangle
{
public:
void setABC(double x, double y, double z);//置三边的值,注意要能成三角形
void getABC(double *x, double *y, double *z);//取三边的值
double perimeter(void);//计算三角形的周长
bool judge();
double area(void);//计算并返回三角形的面积
private:
double a,b,c; //三边为私有成员数据
};
int main()
{
Triangle tri1; //定义三角形类的一个实例(对象)
tri1.setABC(4,5,6); //为三边置初值
double x,y,z;
tri1.getABC (&x,&y,&z);//将三边的值为x,y,z赋值
if (tri1.judge())
{
cout<<"三条边为:"<<x<<'\t'<<y<<'\t'<<z<<endl;
cout<<"三角形的周长为:"<< tri1.perimeter()<<'\t'<<"面积为:"<< tri1.area()<<endl;
}
else
{
cout<<"不能构成三角形!。"<<endl;
}
return 0;
}
bool Triangle::judge()
{
return ( (a+b>c) && (a+c>b) && (b+c>a) )?true:false;
}
void Triangle::setABC(double x, double y, double z)
{
a=x;
b=y;
c=z;
}
void Triangle::getABC(double *x, double *y, double *z)
{
*x=a;
*y=b;
*z=c;
}
double Triangle::perimeter()
{
return(a+b+c);
}
double Triangle::area()
{
double s;
s=(a+b+c)/2;
return sqrt(s*(s-a)*(s-b)*(s-c));
}
运行结果: