main函数
/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:赵加响
*完成日期:2014 年 4 月 1 日
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述:三个点坐标
*问题描述:本项目设计一个三角形类,其数据成员不再是三角形三条边的边长,而是三角形的三个顶点。
利用设计的三角形类,输入三角形的三个顶点,求出其面积、周长,并判断其是否为直角三角形和等腰三角形。
*/
#include
#include
#include "cpoint.h" #include "ctriangle.h" using namespace std;int main() { CPoint a,b,c; CTriangle C(a,b,c); cout<<"输入顶点坐标:"<
cpoint.cpp函数
#include
#include
#include "cpoint.h" #include "ctriangle.h" double CPoint::Distance(CPoint p) const { return sqrt(pow(x-p.x,2)+pow(y-p.y,2)); } void CTriangle::setbian() { a=A.Distance(B); b=C.Distance(B); c=A.Distance(C);//A点到B点的距离 即c边的长,,, } float CTriangle::perimeter() { return a+b+c; } float CTriangle::area() { return 0.25*sqrt((a+b+c)*(a+b-c)*(a+c-b)*(b+c-a)); } bool CTriangle::isRightTriangle() { if(a*a+b*b==c*c||a*a+c*c==b*b||b*b+c*c==a*a) return true; else return false; } bool CTriangle::isIsoscelesTriangle() { if(a==b||a==c||b==c) return true; else return false; }
cpoint.h函数
#ifndef CPOINT_H_INCLUDED
#define CPOINT_H_INCLUDED
#include
using namespace std;
class CPoint
{
private:
double x;
double y;
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy) {}
double Distance(CPoint p) const;
void input()
{
cin>>x>>y;
}
};
#endif // CPOINT_H_INCLUDED
ctriangle.h函数
#ifndef CTRIANGLE_H_INCLUDED
#define CTRIANGLE_H_INCLUDED
class CTriangle
{
public:
CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z) {} //给出三点的构造函数
void setTriangle(CPoint &X,CPoint &Y,CPoint &Z)
{
A=X;
B=Y;
C=Z;
}
void setbian();
float perimeter(void);//计算三角形的周长
float area(void);//计算并返回三角形的面积
bool isRightTriangle(); //是否为直角三角形
bool isIsoscelesTriangle(); //是否为等腰三角形
private:
CPoint A,B,C; //三顶点
double a,b,c;//三个边
};
#endif // CTRIANGLE_H_INCLUDED

感悟:开始时把两个类的程序放在了一起 老是不对 ,后来发现 应该分开来着