您的位置:首页 > 其它

第四周 项目2-三角形类2

2014-03-20 19:43 363 查看
/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:张凯
*完成日期:2014年 03月19号
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述: 输入三角形三边的长
*问题描述:三角形类2
*程序输出: 输出三角形的面积和周长
*问题分析:略
*算法设计:
*/

#include<iostream>
#include<Cmath>
using namespace std;
class Triangle
{
public:
double perimeter();   //三角形的周长
double area();       //三角形的面积
bool isTriangle();
double setA(int x)
{
a=x;
return a;
}
double setB(int y)
{
b=y;
return b;
}
double setC(int z)
{
c=z;
return c;
}
double getA()
{
return a;
}
double getB()
{
return b;
}
double getC()
{
return c;
}
private:
double a,b,c;
};
int main()
{
Triangle tri1;  //定义三角形类的一个实例(对象)
double x,y,z;
cout<<"请输入三角形的三边:";
cin>>x>>y>>z;
tri1.setA(x);
tri1.setB(y);
tri1.setC(z);   //为三边置初值
if(tri1.isTriangle()==1)
{
cout<<"三条边为:"<<tri1.getA()<<','<<tri1.getB()<<','<<tri1.getC()<<endl;
cout<<"三角形的周长为:"<< tri1.perimeter()<<'\t'<<"面积为:"<< tri1.area()<<endl;
}
else
cout<<"不能构成三角形"<<endl;
return 0;
}
double  Triangle::perimeter(void)
{
return a+b+c;
}
double  Triangle::area(void)
{
double p,s;
p=(a+b+c)/2;
s=sqrt(p*(p-a)*(p-b)*(p-c));
return s;
}
bool  Triangle::isTriangle()
{
bool f=false;
if (a+b>c&&b+c>a&&a+c>b&&a-b<c)
{
f=true;
return f;
}else
{
return f;
}
}


运行结果:

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