C++项目案例圆和点的关系 (涉及知识点:头文件定义类,cpp文件实现类,类和作用域,linux编译运行c++项目)

一.项目描述

点与圆有三种关系:

python 复制代码
点在圆外
点在圆上
点在圆内
python 复制代码
计算点到圆心的距离就能判断点在圆的哪个地方。


二.项目结构

三.include文件

3.1 Circle类的声明

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; //圆心
};

3.2 Point类的声明

Point.h

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

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

四.src文件

4.1 Circle类的定义

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

4.2 Point类的定义

Point.cpp

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

void Point::setX(int x)
{
    m_X = x;
}
void Point::setY(int y)
{
    m_Y = y;
}

// 获取y
int Point::getX()
{
    return m_X;
}

int Point::getY()
{
    return m_Y;
}

五.main.cpp

cpp 复制代码
#include<iostream>

using namespace std;
#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<<"点在圆上"<<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(10);

    //判断两者关系
    isInCircle(c,p);
    
    return 0;
}
相关推荐
沐怡旸5 小时前
【底层机制】std::string 解决的痛点?是什么?怎么实现的?怎么正确用?
c++·面试
River4169 小时前
Javer 学 c++(十三):引用篇
c++·后端
轻松Ai享生活11 小时前
5 节课深入学习Linux Cgroups
linux
感哥11 小时前
C++ std::set
c++
侃侃_天下12 小时前
最终的信号类
开发语言·c++·算法
christine-rr12 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
三坛海会大神55512 小时前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
東雪蓮☆12 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
博笙困了12 小时前
AcWing学习——差分
c++·算法
echoarts12 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust