【C++】点类和圆类的关系判断

在这里插入图片描述

#include <iostream>
#include <string>
using namespace std;
const double PI = 3.14;

class Point{
public:
    void setX(int x){
        m_X = x;
    }
    int getX(){
        return m_X;
    }
    void setY(int y){
        m_Y = y;
    }
    int getY(){
        return m_Y;
    }
private:
    int m_X;
    int m_Y;
};

class Circle{
public:
    void setR(int r){
        m_R = r;
    }
    int getR(){
        return m_R;
    }
    void setCenter(Point center){
        m_Center = center;
    }
    Point getCenter(){
        return m_Center;
    }

private:
    int m_R;
    Point m_Center;
};

void isInCircle(Circle &c, Point &p)
{
    int distance =
            (c.getCenter().getX()-p.getX())*(c.getCenter().getX()-p.getX())
            + (c.getCenter().getY()-p.getY())*(c.getCenter().getY()-p.getY());
    int rDistance = c.getR() * c.getR();
    if (distance == rDistance){
        cout << "shang" << endl;
    }
    else if (distance > rDistance){
        cout << "wai " << endl;
    }
    else
        cout << "nei " << endl;

}

int main() {
    Circle c;
    c.setR(10);
    Point center;
    center.setX(10);
    center.setY(0);
    c.setCenter(center);

    Point p;
    p.setX(10);
    p.setY(10);

    isInCircle(c,p);

    return 0;
}

分文件编写

1.main.cpp

#include <iostream>
#include <string>
using namespace std;
const double PI = 3.14;
#include "circle.h"
#include "point.h"
void isInCircle(Circle &c, Point &p)
{
    int distance =
            (c.getCenter().getX()-p.getX())*(c.getCenter().getX()-p.getX())
            + (c.getCenter().getY()-p.getY())*(c.getCenter().getY()-p.getY());
    int rDistance = c.getR() * c.getR();
    if (distance == rDistance){
        cout << "shang" << endl;
    }
    else if (distance > rDistance){
        cout << "wai " << endl;
    }
    else
        cout << "nei " << endl;

}

int main() {
    Circle c;
    c.setR(10);
    Point center;
    center.setX(10);
    center.setY(0);
    c.setCenter(center);

    Point p;
    p.setX(10);
    p.setY(10);

    isInCircle(c,p);

    return 0;
}

2.point.h:

//
// Created by zy on 2021/9/8.
//
#pragma once
#include "iostream"
using namespace std;

class Point{
public:
    void setX(int x);
    int getX();
    void setY(int y);
    int getY();
private:
    int m_X;
    int m_Y;
};


3.point.cpp:

//
// Created by zy on 2021/9/8.
//
#include "point.h"

void Point::setX(int x){ //Point 表示不是全局函数,而是成员函数
    m_X = x;
}
int Point::getX(){
    return m_X;
}
void Point::setY(int y){
    m_Y = y;
}
int Point::getY(){
    return m_Y;
}


4.circle.h

//
// Created by zy on 2021/9/8.
//
#include "iostream"
using namespace std;
#include "point.h"

class Circle{
public:
    void setR(int r);
    int getR();
    void setCenter(Point center);
    Point getCenter();
private:
    int m_R;
    Point m_Center;
};

5.circle.cpp

//
// Created by zy on 2021/9/8.
//

#include "circle.h"

void Circle::setR(int r){
    m_R = r;
}
int Circle::getR(){
    return m_R;
}
void Circle::setCenter(Point center){
    m_Center = center;
}
Point Circle::getCenter(){
    return m_Center;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

姬霓钛美

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值