【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 复制代码
点在圆内
点在圆上
点在圆外
相关推荐
IronMurphy5 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬5 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership6 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826526 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
芯巧电子6 小时前
03. 电应力分析流程管理器 I 芯巧Cadence 25.1新功能深入学习
科技·cadence·软件
九转成圣6 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
Beginner x_u6 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
SmartRadio6 小时前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
laowangpython7 小时前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫7 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript