/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:刘晓晓
*完成日期:2014年 03月17号
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述: 无
*问题描述:三角形类2
*程序输出:无
*问题分析:
*算法设计:
*/
#include<iostream>
#include<Cmath>
using namespace std;
class Triangle
{
public:
double perimeter(void);//计算三角形的周长
double area(void);
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;
}
bool isTriangle()
{
if (a+b>c&&b+c>a&&a+c>b&&a-b<c)
{
cout<<"能构成三角形。";
}
return true;
}
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())
{
cout<<"三条边为:"<<tri1.getA()<<','<<tri1.getB()<<','<<tri1.getC()<<endl;
cout<<"三角形的周长为:"<< tri1.perimeter()<<'\t'<<"面积为:"<< tri1.area()<<endl;
}
else
cout<<"不能构成三角形"<<endl;
return 0;
}
double Triangle:: perimeter(void )
{
double l;
l=a+b+c;
return l;
}
double Triangle:: area(void)
{
double p,s;
p=(a+b+c)/2;
s=sqrt(p*(p-a)*(p-b)*(p-c));
return s;
}
小小的一个传值,做起来都问题重重的。。。