是一个circle类程序
- 提问者网友:不爱我么
- 2021-05-01 19:51
- 五星知识达人网友:执傲
- 2021-05-01 20:14
根据题意实现代码如下:#include <iostream>
#include <cmath>
#include <string>
using namespace std;
const double PI = 3.14159265358979323846;
class Circle{
public:
Circle():x(0),y(0),r(1){};
Circle(double ix, double iy, double ir):x(ix), y(iy), r(ir){};
double area(){return PI*r*r;}
double perimeter(){return 2*PI*r;}
int relation(Circle &c);
void show();
private:
double x, y, r;
};
int Circle::relation(Circle &c){
double d = sqrt((x - c.x) * (x - c.x) + (y - c.y) * (y - c.y));
if(d > r + c.r)
return -1;
else if(d == r + c.r || d == fabs(r-c.r))
return 1; //相切
else if(d < r + c.r && d > fabs(r - c.r))
return 2; //相交
else
return 3;
}
void Circle::show(){
cout << "圆心为(" << x << ", " << y << "),半径为" << r;
}
class TestCircle{
public:
void run();
void AddCircle(Circle c, int i){p[i] = c;}
private:
Circle p[2];
void testRelation(Circle &m, Circle &n);
void testArea(Circle &c);
void testPerimeter(Circle &c);
};
void TestCircle::run(){
testArea(p[0]);
testPerimeter(p[0]);
testArea(p[1]);
testPerimeter(p[1]);
testRelation(p[0],p[1]);
}
void TestCircle::testRelation(Circle &m, Circle &n){
int s = m.relation(n);
string t = "相离";
if(s == 1){
t = "相切";
}
else if(s == 2){
t = "相交";
}
else if(s == 3){
t = "相容";
}
m.show();
cout << "和";
n.show();
cout << ",两圆" << t << endl;
}
void TestCircle::testArea(Circle &c){
c.show();
cout << ",该圆面积为:" << c.area() << endl;
}
void TestCircle::testPerimeter(Circle &c){
c.show();
cout << ",该圆周长为:" << c.perimeter() << endl;
}
int main(){
double x,y,r;
TestCircle test;
cout << "please input x y r of circle 1:" << endl;
cin >> x >> y >> r;
test.AddCircle(Circle(x,y,r), 0);
cout << "please input x y r of circle 2:" << endl;
cin >> x >> y >> r;
test.AddCircle(Circle(x,y,r), 1);
test.run();
return 0;
}如果感觉还行,还请尽快采纳.