m0_59064448 2021-12-05 18:50 采纳率: 55.6%
浏览 26
已结题

能不能写一个接口?急!

#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;
}


  • 写回答

2条回答 默认 最新

  • 关注

    参考如下:

    #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;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月14日
  • 已采纳回答 12月6日
  • 创建了问题 12月5日

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 如何将下列的“无限压缩存储器”设计出来
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口