第4周-项目3-用多文件组织多个类的程序-三角形类
来源:互联网 发布:win7网络共享无法访问 编辑:程序博客网 时间:2024/04/30 13:50
问题及代码:
/* *Copyright (c)2015,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:Triangle.cpp *作 者:单昕昕 *完成日期:2015年4月4日 *版 本 号:v1.0 * *问题描述:将项目2用“一个项目多个文件”的方式实现,其中两个类的声明放在同一个.h文件中,每个类的成员函数分别放一个文件,main()函数用一个文件。体会这样安排的优点。回想Engineer类的数据成员,有眼镜、背包等。某Engineer的眼镜、背包,是Glass、Bag类的对象。类中的数据成员,其类型可以是简单类型,也可以是类。通过这种方式,将某些类组合到另外的类中,当作其中的一个“部件”使用。本项目设计一个三角形类,其数据成员不再是三角形三条边的边长,而是三角形的三个顶点。利用设计的三角形类,输入三角形的三个顶点,求出其面积、周长,并判断其是否为直角三角形和等腰三角形。提示:(1)这个问题需要用到两个类,顶点类参照项目1中的CPoint类;(2)三角形类参考下面CTriangle类的声明;(3)充分利用CPoint类中已有的代码实现;(4)关于三条边长的处理,可以增加三个私有属性,在初始化时求出来备用。当然,也可以在需要用到时再计算。*程序输入:三角形的三个顶点的坐标。*程序输出:三角形的面积、周长,并判断其是否为直角三角形和等腰三角形。*/ #include <iostream>#include <cmath>using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0); double Distance1(CPoint p) const; //两点之间的距离 void input(); //以x,y 形式输入坐标点};CPoint::CPoint(double xx,double yy){ x=xx; y=yy;}void CPoint::input()//以x,y 形式输入坐标点{ cout<<"以x,y 形式输入坐标点:"; char c; cin>>x>>c>>y;}double CPoint::Distance1(CPoint p) const//两点之间的距离{ return sqrt((p.x-x)*(p.x-x)+((p.y-y)*(p.y-y)));}class CTriangle{public: CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z) {} //给出三点的构造函数 void setTriangle(CPoint &X,CPoint &Y,CPoint &Z); float perimeter(void);//计算三角形的周长 float area(void);//计算并返回三角形的面积 bool isRightTriangle(); //是否为直角三角形 bool isIsoscelesTriangle(); //是否为等腰三角形private: CPoint A,B,C; //三顶点};void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){ A=X; B=Y; C=Z;}float CTriangle::perimeter(void)//计算三角形的周长{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); cout<<"AB="<<ab<<'\t'<<"AC="<<ac<<'\t'<<"BC="<<bc<<'\t'<<endl; return (ab+ac+bc);}float CTriangle::area(void)//计算并返回三角形的面积{ double ab,ac,bc,s; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); s=(ab+ac+bc)/2; return sqrt(s*(s-ab)*(s-ac)*(s-bc));}bool CTriangle::isRightTriangle()//是否为直角三角形{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); if((ab*ab+ac*ac==bc*bc)||(bc*bc+ac*ac==ab*ab)||(ab*ab+bc*bc==ac*ac)) return true; else return false;}bool CTriangle::isIsoscelesTriangle()//是否为等腰三角形{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); if((ab==bc)||(bc==ac)||(ab==ac)) return true; else return false;}int main(){ CPoint A,B,C; A.input(); B.input(); C.input(); CTriangle t(A,B,C); cout<<"三角形的周长="<<t.perimeter()<<endl; cout<<"三角形的面积="<<t.area()<<endl; if(t.isRightTriangle()) cout<<"该三角形是直角三角形"<<endl; else cout<<"该三角形不是直角三角形"<<endl; if(t.isIsoscelesTriangle()) cout<<"该三角形是等腰三角形"<<endl; else cout<<"该三角形不是等腰三角形"<<endl; return 0;}
程序的多文件组织:
——————————————————主文件: main.cpp,用于定义main()函数
#include <iostream>#include <cmath>#include "Triangle.h"using namespace std;int main(){ CPoint A,B,C; A.input(); B.input(); C.input(); CTriangle t(A,B,C); cout<<"三角形的周长="<<t.perimeter()<<endl; cout<<"三角形的面积="<<t.area()<<endl; if(t.isRightTriangle()) cout<<"该三角形是直角三角形"<<endl; else cout<<"该三角形不是直角三角形"<<endl; if(t.isIsoscelesTriangle()) cout<<"该三角形是等腰三角形"<<endl; else cout<<"该三角形不是等腰三角形"<<endl; return 0;}
运行结果:
——————————————————头文件: Triangle.h,两个类的声明放在同一个.h文件中
#ifndef TRIANGLE_H_INCLUDED#define TRIANGLE_H_INCLUDEDclass CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0); double Distance1(CPoint p) const; //两点之间的距离 void input(); //以x,y 形式输入坐标点};class CTriangle{public: CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z) {} //给出三点的构造函数 void setTriangle(CPoint &X,CPoint &Y,CPoint &Z); float perimeter(void);//计算三角形的周长 float area(void);//计算并返回三角形的面积 bool isRightTriangle(); //是否为直角三角形 bool isIsoscelesTriangle(); //是否为等腰三角形private: CPoint A,B,C; //三顶点};#endif // TRIANGLE_H_INCLUDED
运行结果:
——————————————————CPoint类的成员函数:
#include <iostream>#include <cmath>#include "Triangle.h"using namespace std;CPoint::CPoint(double xx,double yy){ x=xx; y=yy;}void CPoint::input()//以x,y 形式输入坐标点{ cout<<"以x,y 形式输入坐标点:"; char c; cin>>x>>c>>y;}double CPoint::Distance1(CPoint p) const//两点之间的距离{ return sqrt((p.x-x)*(p.x-x)+((p.y-y)*(p.y-y)));}
运行结果:
——————————————————CTriangle类的成员函数:
#include <iostream>#include <cmath>#include "Triangle.h"using namespace std;void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){ A=X; B=Y; C=Z;}float CTriangle::perimeter(void)//计算三角形的周长{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); cout<<"AB="<<ab<<'\t'<<"AC="<<ac<<'\t'<<"BC="<<bc<<'\t'<<endl; return (ab+ac+bc);}float CTriangle::area(void)//计算并返回三角形的面积{ double ab,ac,bc,s; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); s=(ab+ac+bc)/2; return sqrt(s*(s-ab)*(s-ac)*(s-bc));}bool CTriangle::isRightTriangle()//是否为直角三角形{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); if((ab*ab+ac*ac==bc*bc)||(bc*bc+ac*ac==ab*ab)||(ab*ab+bc*bc==ac*ac)) return true; else return false;}bool CTriangle::isIsoscelesTriangle()//是否为等腰三角形{ double ab,ac,bc; ab=A.Distance1(B); ac=A.Distance1(C); bc=B.Distance1(C); if((ab==bc)||(bc==ac)||(ab==ac)) return true; else return false;}
运行结果:
知识点总结:
用多文件组织多个类的程序。
学习心得:
新技能get~
0 0
- 第4周-项目3-用多文件组织多个类的程序-三角形类
- 第3周项目3-三角形类(程序的多文件组织)
- 第2周-项目3-程序的多文件组织-三角形类
- 第四周项目 3 用多文件组织多个类的程序
- 第7周项目3多文件组织类的程序
- 三角形类3--程序的多文件组织
- 第3周项目3三角形类2的多文件组织形式
- 用多文件组织多个类的程序-三角形类
- 第3周项目3--多文件组织三角形
- C++第6周项目5 - 多文件组织三角形类
- C++第6周项目5 - 多文件组织三角形类
- 第5周项目多文件组织三角形类
- 第4周项目4-用多文件组织多个类的程序
- C++第6周(春)项目3 用多文件组织多个类的程序
- 第5周项目3-用多文件组织多个类的程序-对象作数组成员
- 2015-第5周项目3-用多文件组织多个类的程序
- 第5周项目3-用多文件组织多个类的程序
- 第5周项目3-用多文件组织多个类的程序
- mvc思想
- 未能加载文件或程序集"System.Data,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089"或它的某一个依赖项。系统找
- nginx禁止访问某个后缀名的文件
- Linux 内核启动过程分析----zImage自解压
- ObjectiveC类的使用
- 第4周-项目3-用多文件组织多个类的程序-三角形类
- Hadoop学习之HBase的伪分布式安装
- P52第24题 完数问题
- hdu 1485 非常可乐 题解
- linux密码加密方式与暴力破解代码
- thinking in java 第二天
- 第四周上机项目1 三角形类的构造函数
- 第四周项目三用对象数组操作长方柱类
- leetcode-13 Roman to Integer