六周 项目3 用多文件组织多个类的程序

来源:互联网 发布:centos yum 源更新 编辑:程序博客网 时间:2024/05/19 04:06

main函数

/**程序的版权和版本声明部分:*Copyright(c)2014,烟台大学计算机学院学生*All rights reserved.*文件名称:*作者:赵加响*完成日期:2014  年 4 月 1 日*版本号:v1.0*对任务及求解方法的描述部分:*输入描述:三个点坐标*问题描述:本项目设计一个三角形类,其数据成员不再是三角形三条边的边长,而是三角形的三个顶点。           利用设计的三角形类,输入三角形的三个顶点,求出其面积、周长,并判断其是否为直角三角形和等腰三角形。*/#include <iostream>#include <cmath>#include "cpoint.h"#include "ctriangle.h"using namespace std;int main(){    CPoint a,b,c;    CTriangle C(a,b,c);    cout<<"输入顶点坐标:"<<endl;    a.input();    b.input();    c.input();    C.setTriangle(a,b,c);    C.setbian();    cout << "三角形周长:" << endl;    cout <<C.perimeter()<< endl;    cout << "三角形面积:" << endl;    cout <<C.area()<< endl;   if(C.isIsoscelesTriangle())cout<<"是等腰三角形。"<<endl;elsecout<<"不是等腰三角形。"<<endl;if(C.isRightTriangle())cout<<"是直角三角形。"<<endl;elsecout<<"不是直角三角形。"<<endl;    return 0;}


cpoint.cpp函数

#include <iostream>#include <cmath>#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 <iostream>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_INCLUDEDclass 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


 

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

0 0
原创粉丝点击