第六周项目四----用点类做成员的三角形类以及多文件组织的三角形类
来源:互联网 发布:latex windows 10 编辑:程序博客网 时间:2024/05/22 15:14
/** 程序的版权和版本声明部分* Copyright (c)2013, 烟台大学计算机学院学生* All rightsreserved.* 文件名称: object.cpp* 作者:赵晓晨* 完成日期: 2013年04月08日* 版本号: v1.0* 输入描述:无* 问题描述:无* 程序输出:无*/#include <iostream>#include <Cmath>using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0); double distance(CPoint p) const; // 两点之间的距离 void input(); //以x,y 形式输入坐标点 void output(); //以(x,y) 形式输出坐标点};class CTriangle{private: CPoint A,B,C; //三顶点public: CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z){} //给出三点的构造函数 void setTriangle(CPoint &X,CPoint &Y,CPoint &Z);// double perimeter(void);//计算三角形的周长 double area(void);//计算并返回三角形的面积 bool isRightTriangle(); //是否为直角三角形 bool isIsoscelesTriangle(); //是否为等腰三角形};CPoint::CPoint(double xx,double yy){ x=xx; y=yy;}//class point 中void CPoint::input(){ char ch; cout<<"请输入坐标点(格式x,y ):"; while(1) { cin>>x>>ch>>y; if (ch==',') break; cout<<"输入的数据格式不规范,请重新输入\n"; }}void CPoint::output(){ cout<<"("<<x<<", "<<y<<")"<<endl;}double CPoint::distance(CPoint p) const{ double d; d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y)); return d;}//class CTriangle 中void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){ A=X; B=Y; C=Z;}double CTriangle::perimeter(void){ double a=B.distance(C),b=C.distance(A),c=A.distance(B); return (a + b + c);}double CTriangle::area(void){ double a=B.distance(C),b=C.distance(A),c=A.distance(B); double s = (a + b + c) / 2; return sqrt(s * (s - a) * (s - b) * (s - c));}bool CTriangle::isRightTriangle()//是否为直角三角形{ double a=B.distance(C),b=C.distance(A),c=A.distance(B); double max=a; if(b>max) max=b; if(c>max) max=c; if(((max==a)&&(abs(a*a-b*b-c*c)<1e-7))||((max==b)&&(abs(b*b-a*a-c*c)<1e-7))||((max==c)&&(abs(c*c-b*b-a*a)<1e-7))) return true; else return false;}bool CTriangle::isIsoscelesTriangle() //是否为等腰三角形{ double a=B.distance(C),b=C.distance(A),c=A.distance(B); if((abs(a-b)<1e-7)||(abs(b-c)<1e-7)||(abs(c-a)<1e-7)) return true; else return false;}//定义main函数int main(){ CPoint X(2,5),Y(5,2),Z(7,8); CTriangle Tri1(X,Y,Z); //定义三角形类的一个实例(对象) cout<<"该三角形的周长为:"<<Tri1.perimeter()<<",面积为:"<<Tri1.area()<<endl<<endl; cout<<"该三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl; cout<<"该三角形"<<(Tri1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl; return 0;}
结果:
体会:
(1)这个问题需要用到两个类,顶点类参照任务3中的CPoint类;(2)三角形类参考下面CTriangle类的声明;(3)充分利用CPoint类中已有的代码实现;(4)关于三条边的处理,可以增加三个私有属性,在初始化时求出来备用,也可以在需要时计算得到。
/** 程序的版权和版本声明部分* Copyright (c)2013, 烟台大学计算机学院学生* All rightsreserved.* 文件名称: object.cpp* 作者:赵晓晨* 完成日期: 2013年04月08日* 版本号: v1.0* 输入描述:无* 问题描述:无* 程序输出:无*///1.两个类的声明#include <iostream>#include <Cmath>using namespace std;class CPoint{private: double x; // 横坐标 double y; // 纵坐标public: CPoint(double xx=0,double yy=0); double distance(CPoint p) const; // 两点之间的距离 void input(); //以x,y 形式输入坐标点 void output(); //以(x,y) 形式输出坐标点};class CTriangle{private: CPoint A,B,C; //三顶点public: CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z){} //给出三点的构造函数 void setTriangle(CPoint &X,CPoint &Y,CPoint &Z);// double perimeter(void);//计算三角形的周长 double area(void);//计算并返回三角形的面积 bool isRightTriangle(); //是否为直角三角形 bool isIsoscelesTriangle(); //是否为等腰三角形};CPoint::CPoint(double xx,double yy){ x=xx; y=yy;}//2.每个类的成员函数void CPoint::input(){ char ch; cout<<"请输入坐标点(格式x,y ):"; while(1) { cin>>x>>ch>>y; if (ch==',') break; cout<<"输入的数据格式不规范,请重新输入\n"; }}void CPoint::output(){ cout<<"("<<x<<", "<<y<<")"<<endl;}double CPoint::distance(CPoint p) const{ double d; d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y)); return d;}//class CTriangle 中void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){ A=X; B=Y; C=Z;}double CTriangle::perimeter(void){ double a=B.distance(C),b=C.distance(A),c=A.distance(B); return (a + b + c);}double CTriangle::area(void){ double a=B.distance(C),b=C.distance(A),c=A.distance(B); double s = (a + b + c) / 2; return sqrt(s * (s - a) * (s - b) * (s - c));}bool CTriangle::isRightTriangle()//是否为直角三角形{ double a=B.distance(C),b=C.distance(A),c=A.distance(B); double max=a; if(b>max) max=b; if(c>max) max=c; if(((max==a)&&(abs(a*a-b*b-c*c)<1e-7))||((max==b)&&(abs(b*b-a*a-c*c)<1e-7))||((max==c)&&(abs(c*c-b*b-a*a)<1e-7))) return true; else return false;}bool CTriangle::isIsoscelesTriangle() //是否为等腰三角形{ double a=B.distance(C),b=C.distance(A),c=A.distance(B); if((abs(a-b)<1e-7)||(abs(b-c)<1e-7)||(abs(c-a)<1e-7)) return true; else return false;}//3.main.cpp# include <iostream>using namespace std;int main(){ CPoint X(2,5),Y(5,2),Z(7,8); CTriangle Tri1(X,Y,Z); //定义三角形类的一个实例(对象) cout<<"该三角形的周长为:"<<Tri1.perimeter()<<",面积为:"<<Tri1.area()<<endl<<endl; cout<<"该三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl; cout<<"该三角形"<<(Tri1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl; return 0;}
体会:
用“一个项目多个文件”的方式实现,其中两个类的声明放在一个.h文件中,每个类的成员函数分别放一个文件,main()函数用一个文件。
- 第六周项目四----用点类做成员的三角形类以及多文件组织的三角形类
- 用点类做成员的三角形类
- C++第6周项目4 - 用点类做成员的三角形类
- test9-5(用点类做成员的三角形类)
- 第六周—多文件组织三角形类
- 第六周 项目四 求三角形面积,周长的类
- 第六周任务五。多文件组织三角形类
- 三角形类3--程序的多文件组织
- 程序的多文件组织-三角形类
- 多文件组织---三角形类
- 第2周-项目3-程序的多文件组织-三角形类
- 第3周项目3-三角形类(程序的多文件组织)
- 第三周项目三 程序的多文件组织(三角形类)
- 第3周项目3三角形类2的多文件组织形式
- 第二学期第三周项目3 三角形类的多文件组织
- 第4周-项目3-用多文件组织多个类的程序-三角形类
- C++第6周项目5 - 多文件组织三角形类
- C++第6周项目5 - 多文件组织三角形类
- 公司内部管理系统-用YII开发中遇到的问题(更新中...)
- 在剪切板中使用自定义格式的数据
- yocto project terms & 深入理解 BitBake
- Citrix_XenServer-6.1安装过程详解
- 分析交换两个整数的特殊写法
- 第六周项目四----用点类做成员的三角形类以及多文件组织的三角形类
- LINUX下java环境的设置
- 谈谈网络安全的ARP攻击防护以及工具分享
- 想学编程?这样开始
- 使用 Xcode 在越狱 iOS 设备上进行开发调试
- 安装LoadRunner时出现“计算机缺少vc2005_sp1_with_atl_fix_redist”的解决办法
- Oracle触发器4-数据库事件触发器
- 智能指针(指向转移写法)
- poj 3468 A Simple Problem with Integers