本文主要是介绍第五周项目三---多文件组织多个类的程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
问题及代码:
main.cpp
/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:test.cpp
*作 者:尚 月
*完成日期:2015年04月05日
*版 本 号:v1.0
*
*问题描述:在坐标上输入三角巷的三个顶点坐标,输出其周长和面积,并判断是是什么三角形
*输入描述:输入三个顶点值
*输出描述:输出周长和面积,判断是什么三角形
*/
#include <iostream>
#include <cmath>
#include"CPoint.h"
using namespace std;
int main()
{
CPoint X,Y,Z;
X.input();
Y.input();
Z.input();
CTriangle Tri1(X,Y,Z);
cout<<"该三角形的周长为:"<<Tri1.perimeter()<<endl;
cout<<"面积为:"<<Tri1.area()<<endl;
cout<<"该三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl;
cout<<"该三角形"<<(Tri1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl;
return 0;
}
CPoint.h
#ifndef CPOINT_H_INCLUDED
#define CPOINT_H_INCLUDED
class CPoint
{
private:
double x; //横坐标
double y; //纵坐标
public:
CPoint(double xx=0,double yy=0);
double Distance1(CPoint p) const; //两点之间的距离
double Distance0() const; //到原点(0,0)的距离
CPoint SymmetricAxis(char style) const; //style取'x','y'和'o'分别表示按X轴Y轴,原点对称
void input(); //x,y形式输入坐标点
void output(); //以(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; //三顶点
double a=B.Distance1(C);
double b=C.Distance1(A);
double c=A.Distance1(B);
};
#endif // CPOINT_H_INCLUDED
CPoint.cpp
#include<iostream>
#include<cmath>
#include"CPoint.h"
using namespace std;
void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)
{
A=X;
B=Y;
C=Z;
}
float CTriangle::perimeter(void)
{
return (a+b+c);
}
float CTriangle::area(void)
{
double s=(a+b+c)/2;
return sqrt(s*(s-a)*(s-b)*(s-c));
}
CPoint::CPoint(double xx,double yy)
{
x=xx;
y=yy;
}
void CPoint::input()
{
char c;
cout<<"请输入坐标点(x,y):";
while(cin>>x>>c>>y)
{
if(c!=',')
cout<<"对不起,您的输入有误!";
else
break;
}
}
double CPoint::Distance1(CPoint p)const
{
return sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
}
// 求点到原点的距离
double CPoint::Distance0() const
{
return sqrt(x*x+y*y);
}
CPoint CPoint::SymmetricAxis(char style) const
{
CPoint p(p.x,p.y);//用复制构造函数时,写作p(*this)
switch(style)
{
case 'x':
p.x=x;
p.y=-y;
break;
case 'y':
p.x=-x;
break;
case 'o':
p.x=-x;
p.y=-y;
}
return p;
}
void CPoint::output()
{
cout<<"("<<x<<", "<<y<<")"<<endl;
}
bool CTriangle::isRightTriangle()//是否为直角三角形
{
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() //是否为等腰三角形
{
if((abs(a-b)<1e-7)||(abs(b-c)<1e-7)||(abs(c-a)<1e-7))
return true;
else
return false;
}
运行结果:
学习总结:在项目二的基础上改成一个多文件组织就OK了~~
这篇关于第五周项目三---多文件组织多个类的程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!