第六周任务4:三角形“类”的新做法

来源:互联网 发布:模糊算法有什么 编辑:程序博客网 时间:2024/04/30 13:00
#include <iostream>#include <cmath>using namespace std;class CPoint{private: mutable double x;  // 横坐标 mutable double y;  // 纵坐标public: CPoint(double xx=0,double yy=0); double Distance(CPoint p) const;   // 两点之间的距离(一点是当前点,另一点为参数p) 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);// double perimeter(void);//计算三角形的周长 double area(void);//计算并返回三角形的面积 bool isRightTriangle(); //是否为直角三角形 bool isIsoscelesTriangle(); //是否为等腰三角形private: CPoint A,B,C; //三顶点};CPoint::CPoint(double xx,double yy){ x=xx; y=yy;}//以x,y 形式输入坐标点void CPoint::input(){ char c; while(1) {  cout<<"请按照x,y格式输入"<<endl;  cin>>x>>c>>y;  if(c!=',')   cout<<"格式不对,请重新输入"<<endl;  else   break; }}// 两点之间的距离(一点是当前点,另一点为参数p)double CPoint::Distance(CPoint p) const{ double s; s=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y)); return s;} //以(x,y) 形式输出坐标点void CPoint::output(){ cout<<'('<<x<<','<<y<<')';}void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){ A = X; B = Y; C = Z;}//计算三角形的周长 double CTriangle::perimeter(void){ double a,b,c; a = B.Distance(C); b = A.Distance(C); c = A.Distance(B); return (a+b+c);}//计算并返回三角形的面积double CTriangle::area(void){ double a,b,c,s; a = B.Distance(C); b = A.Distance(C); c = A.Distance(B); s = (a+b+c)/2; return sqrt(s*(s-a)*(s-b)*(s-c));}//是否为直角三角形bool CTriangle::isRightTriangle(){ double a,b,c; a = B.Distance(C); b = A.Distance(C); c = A.Distance(B); if((abs(a*a+b*b-c*c<1e-6)) || (abs(a*a+c*c-b*b<1e-6)) || (abs(b*b+c*c-a*a<1e-6)))  return true; else  return false;}//是否为等腰三角形bool CTriangle::isIsoscelesTriangle(){ double a,b,c; a = B.Distance(C); b = A.Distance(C); c = A.Distance(B); if((abs(a-b<1e-7)) || (abs(a-c<1e-7)) || (abs(b-c<1e-7)))  return true; else  return false;}void main(void){   CTriangle tr1(CPoint (1,4),CPoint (0,0),CPoint (6,0)); cout<<"该三角形周长:"<<tr1.perimeter(); cout<<"面积:"<<tr1.area(); cout<<endl; cout<<"该三角形"<<(tr1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl; cout<<"该三角形"<<(tr1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl;  system ("pause");}


贺老师 程序里有个错误:应该不是 等腰三角形的,但输出却是等腰三角形。。。不知道是哪里搞错了,望老师指点一下。。。。