【C++】封装:练习案例-点和圆的关系

练习案例:点和圆的关系

设计一个圆形类(Circle),和一个点类(Point),计算点和圆的关系。

思路:

1)创建点类point.hpoint.cpp

2)创建圆类circle.hcircle.cpp

3)点和圆的关系判断void isIncircle(Circle &c,Point &p)

点到圆心的距离 == 圆心 (点在圆上)

点到圆心的距离 < 圆心 (点在圆内)

点到圆心的距离 > 圆心 (点在圆外)

示例代码

我们将点类用point.cpppoint.h实现。将圆类用circle.cppcircle.h实现。

点类头文件point.h

cpp 复制代码
#pragma once
#include<iostream>
using namespace std;
class Point
{
public:
	//设置x坐标
	void setX(int x);
	
	//读取x坐标
	int getX();
	
	//设置y坐标
	void setY(int y);
	
	//读取y坐标
	int getY();
	
private:
	int m_x;
	int m_y;
};

点类代码实现point.c

cpp 复制代码
#include"point.h"

//设置x坐标
void Point::setX(int x)
{
	m_x = x;
}
//读取x坐标
int Point::getX()
{
	return m_x;
}
//设置y坐标
void Point::setY(int y)
{
	m_y = y;
}
//读取y坐标
int Point::getY()
{
	return m_y;
}

圆类头文件circle.h

cpp 复制代码
#pragma once
#include<iostream>
#include"point.h"
using namespace std;

class Circle
{
public:
	//设置半径
	void setR(int r);
	
	//读取半径
	int getR();
	
	//设置圆心
	void setCenter(Point center);
	
	//获取圆心
	Point getCenter();
	
private:
	int m_R; //半径
	//在类中可以让另一个类,作为本类中的成员
	Point m_center; //圆心

};

圆类代码实现circle.cpp

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

主文件点和圆的关系.cpp

cpp 复制代码
#include<iostream>
#include"circle.h"
#include"point.h"
using namespace std;
//点和圆的关系案例

//判断点和圆的关系
void isIncircle(Circle &c,Point &p)
{
	//计算两点距离的平方
	int dist =
	(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 (dist == rDistance)
	{
		cout << "点在圆上" << endl;
	}
	else if (dist > rDistance)
	{
		cout << "点在圆外" << endl;
	}
	else
	{
		cout << "点在圆内" << endl;
	}
}
int main()
{
	//创建圆
	Circle c1;
	c1.setR(10);
	Point center;
	center.setX(10);
	center.setY(0);
	c1.setCenter(center);

	//创建点
	Point p1;
	p1.setX(10);
	p1.setY(9);

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

	Point p3;
	p3.setX(10);
	p3.setY(11);

	//判断关系
	isIncircle(c1, p1);
	isIncircle(c1, p2);
	isIncircle(c1, p3);

	system("pause");
	return 0;
}

运行结果

我们设置了一个圆,圆心为(10,0),半径为10。

我们设置了三个点(10,9)(10,10)(10,11)。

cpp 复制代码
点在圆内
点在圆上
点在圆外
相关推荐
2301_781913056 分钟前
图论系列(dfs深搜)9.21
算法·深度优先·图论
边疆.7 分钟前
数据结构:内部排序
c语言·开发语言·数据结构·算法·排序算法
qmx_078 分钟前
MFC -文件类控件
c++·mfc
arin8769 分钟前
【图论】最短路应用
数据结构·算法
菜鸟求带飞_9 分钟前
算法打卡:第十一章 图论part03
java·数据结构·算法·深度优先·图论
木子欢儿17 分钟前
在 Debian 12 上安装 Java 21
java·运维·开发语言·debian
终末圆21 分钟前
MyBatis XML映射文件编写【后端 18】
xml·java·开发语言·后端·算法·spring·mybatis
就这个java爽!21 分钟前
超详细的XML介绍【附带dom4j操作XML】
xml·java·开发语言·数据库·青少年编程·eclipse
Damon小智23 分钟前
C#进阶-基于雪花算法的订单号设计与实现
开发语言·算法·c#·雪花算法·订单号
_.Switch27 分钟前
Python Web 架构设计与性能优化
开发语言·前端·数据库·后端·python·架构·log4j