#include <iostream>
#include <math.h>
using namespace std;
class Point
{
public:
double x,y;
Point(){x=0;y=0;}
Point(int xx,int yy){x=xx;y=yy;}
};
class Circle
{
public:
Point center;
double radius;
Circle(){}
Circle(Point p,double r)
{
center = p;
radius = r;
}
void fun(Point p)
{
double dis = sqrt( (center.x-p.x)*(center.x-p.x) + (center.y-p.y)*(center.y-p.y) );
if(dis < radius)
cout << "在圆内"<< endl;
else if(dis == radius)
cout << "在圆上"<< endl;
else
cout << "在圆外" << endl;
}
};
class Triangle
{
public:
Point a,b,c;
Triangle(){}
Triangle(Point x,Point y,Point z)
{
a =x;b=y;c=z;
double l1 = sqrt( (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y) );
double l2 = sqrt( (a.x-c.x)*(a.x-c.x)+(a.y-c.y)*(a.y-c.y) );
double l3 = sqrt( (b.x-c.x)*(b.x-c.x)+(b.y-c.y)*(b.y-c.y) );
if(l1 +l2 <= l3 || l2+l3 <= l1 || l1+l3<= l2)
cout << "不能组成三角形";
}
double getzc()
{
double l1 = sqrt( (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y) );
double l2 = sqrt( (a.x-c.x)*(a.x-c.x)+(a.y-c.y)*(a.y-c.y) );
double l3 = sqrt( (b.x-c.x)*(b.x-c.x)+(b.y-c.y)*(b.y-c.y) );
if(l1 +l2 <= l3 || l2+l3 <= l1 || l1+l3<= l2)
{
return -1;
}
else
return (l1 + l2 +l3);
}
};
int main()
{
Circle c(Point(2,2),1);
c.fun(Point(1,1));
Triangle tr(Point(0,0),Point(1,0),Point(0,1));
if (tr.getzc() < 0)
{
cout <<"不构成三角形"<<endl;
}else
cout <<"周长="<<tr.getzc()<<endl;
return 0;
}
能不能写一个接口?急!
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 技术专家团-小桥流水 2021-12-05 19:05关注
参考如下:
#include <iostream> #include <math.h> using namespace std; //抽象类 class MyObject { public: virtual double getzc()=0; }; class Point { public: double x,y; Point(){x=0;y=0;} Point(int xx,int yy){x=xx;y=yy;} }; class Circle :public MyObject { public: Point center; double radius; Circle(){} Circle(Point p,double r) { center = p; radius = r; } double getzc() { return 2*3.1415926*radius; } void fun(Point p) { double dis = sqrt( (center.x-p.x)*(center.x-p.x) + (center.y-p.y)*(center.y-p.y) ); if(dis < radius) cout << "在圆内"<< endl; else if(dis == radius) cout << "在圆上"<< endl; else cout << "在圆外" << endl; } }; class Triangle :public MyObject { public: Point a,b,c; Triangle(){} Triangle(Point x,Point y,Point z) { a =x;b=y;c=z; double l1 = sqrt( (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y) ); double l2 = sqrt( (a.x-c.x)*(a.x-c.x)+(a.y-c.y)*(a.y-c.y) ); double l3 = sqrt( (b.x-c.x)*(b.x-c.x)+(b.y-c.y)*(b.y-c.y) ); if(l1 +l2 <= l3 || l2+l3 <= l1 || l1+l3<= l2) cout << "不能组成三角形"; } double getzc() { double l1 = sqrt( (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y) ); double l2 = sqrt( (a.x-c.x)*(a.x-c.x)+(a.y-c.y)*(a.y-c.y) ); double l3 = sqrt( (b.x-c.x)*(b.x-c.x)+(b.y-c.y)*(b.y-c.y) ); if(l1 +l2 <= l3 || l2+l3 <= l1 || l1+l3<= l2) { return -1; } else return (l1 + l2 +l3); } }; int main() { Circle c(Point(2,2),1); c.fun(Point(1,1)); Triangle tr(Point(0,0),Point(1,0),Point(0,1)); if (tr.getzc() < 0) { cout <<"不构成三角形"<<endl; }else cout <<"周长="<<tr.getzc()<<endl; return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 win11修改中文用户名路径
- ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
- ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
- ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
- ¥15 帮我写一个c++工程
- ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
- ¥15 关于smbclient 库的使用
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
- ¥20 怎么用dlib库的算法识别小麦病虫害