头文件circle.h
#pragma once
#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;
};
头文件point.h
#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;
};
源文件01.cpp
#include <iostream>
using namespace std;
#include <string.h>
#include "circle.h"
#include "point.h"
//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 << "点在圆上" << endl;
}
else if (distance < rdistance) {
cout << "点在圆内" << endl;
}
else {
cout << "点在圆外" << 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(13);
isincircle(c, p);
system("pause");
return 0;
}
源文件circle.cpp
#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;
}
源文件point.cpp
#include "point.h"
void point::setx(int x) {
m_x = x;
}
int point::getx() {
return m_x;
}
void point::sety(int y) {
m_y = y;
}
int point::gety() {
return m_y;
}