/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:score.cpp
* 作 者:张浩
* 完成日期:2013年3月23日
* 版本号: v1.0
* 输入描述:输入三角形的三条边长
* 问题描述: 计算三角形的面积和周长
* 输出: 输出三角形的面积和周长
*/
头文件Triangl.h
class Triangle
{
private:
double a,b,c;//三边为私有成员数据
public:
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);//计算并返回三角形的面积
bool isTriangle();//三角形成立的条件
};
用于定义类的triangl.cpp
#include"Triandle.h"
#include<Cmath>
bool Triangle::isTriangle()
{
return ((a+b <= c)||(a+c <= b)||(c+b <= a));
}
double Triangle::perimeter()
{
double m;
m=a+b+c;
return m;
}
double Triangle::area(void)
{
double s,p;
p=(a+b+c)*0.5;
s=sqrt(p*(p-a)*(p-b)*(p-c));
return s;
}
用于写测试程序的main.cp
#include<iostream>
#include"Triangle.h"
using namespace std;
int main()
{
Triangle tri1;
double x,y,z;
cout<<"请输入三角形的三条边长:"<<endl;
cin>>x>>y>>z;
tri1.setA(x);tri1.setB(y);tri1.setC(z); //为三边置初值
while(tri1.isTriangle())
{
cout<<"不能构成三角形!"<<'\n'<<"还是重新输入吧。。。。"<<endl;
cin>>x>>y>>z;
tri1.setA(x);tri1.setB(y);tri1.setC(z); //为三边置初值
}
cout<<"三条边为:"<<x<<'\t'<<y<<'\t'<<z<<endl;
cout<<"三角形的周长为:"<<tri1.perimeter()<<'\n'<<"三角形的面积为:"<<tri1.area()<<endl;
system("pause");
return 0;
}
心得体会:这样写分工更明确,更有条理性!