判断点与圆的位置关系

#include<iostream>

using namespace std;

class point//点

{

public:

void setX(int x)

{

mx = x;

}

int getX()

{

return mx;

}

void setY(int y)

{

my = y;

}

int getY()

{

return my;

}

private:

int mx;

int my;

};

class circle//圆

{

public:

void setR(int R)

{

mr = R;

}

int getR()

{

return mr;

}

void setP(point p)

{

mp = p;

}

point getP()

{

return mp;

}

private:

int mr;

point mp;

};

void isin(circle& c, point& p)//求点到圆的距离函数

{

int d=

(c.getP().getX() - p.getX())* (c.getP().getX() - p.getX()) -

(c.getP().getY() - p.getY()) * (c.getP().getY() - p.getY());

int l = c.getR()*c.getR();

if (d > l)

{

cout << "圆外" << endl;

}

else if (d == l)

{

cout << "圆上"<< endl;

}

else

{

cout << "圆内" << endl;

}

}

int main()

{

circle c;//定义一个圆

c.setR(10);//圆的半径

point mp;//定义圆心的坐标

mp.setX(10);//圆心为10,0

mp.setY(10);

c.setP(mp);//定义圆心的坐标,但因为圆的坐标是用point定义的,要先定义一个点mp

point p;//定义未知点

p.setX(10);//未知点(10,5)

p.setY(5);

isin(c, p);//套用函数

return 0;

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值