第四周 项目二 三角形类2

/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: array.cpp
* 作    者:王鲁峰
* 完成日期:  2014年 3 月  18 日
* 版本号: v1.0
* 输入描述:无
* 问题描述:
*/

#include<iostream>
#include<Cmath>
using namespace std;
class Triangle
{
public:
 bool isTriangle();
 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;
 }
 double perimeter(void);//计算三角形的周长
 double area(void);//计算并返回三角形的面积
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 d;
    d=a+b+c;
    return d;
}
double Triangle::area(void)
{
    double s;
    s=(1.0/4)*sqrt((a+b+c)*(a+b-c)*(a+c-b)*(b+c-a));
    return s;
}
bool Triangle::isTriangle()
{
    return (a+b>c&&a+c>b&&b+c>a);
}


 

运行结果:

心得体会:

  这个程序做的一般情况 因为当一组数据不能构成三角形时,程序自动退出,如果稍加一更新,我感觉这程序会更好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值