第12周 【项目4 - 点、圆的关系】(3)

问题描述:

(1)先建立一个Point(点)类,包含数据成员x,y(坐标点);

(2)以Point为基类,派生出一个Circle(圆)类,增加数据成员(半径),基类的成员表示圆心;

(3)编写上述两类中的构造、析构函数及必要运算符重载函数(本项目主要是输入输出);

(4)定义友元函数int locate,判断点p与圆的位置关系(返回值<0圆内,==0圆上,>0 圆外);

int main( )
{
	Circle c1(3,2,4),c2(4,5,5);      //c2应该大于c1
	Point p1(1,1),p2(3,-2),p3(7,3);  //分别位于c1内、上、外

	cout<<"圆c1: "<<c1;

	cout<<"点p1: "<<p1;
	cout<<"点p1在圆c1之"<<((locate(p1, c1)>0)?"外":((locate(p1, c1)<0)?"内":"上"))<<endl;

	cout<<"点p2: "<<p2;
	cout<<"点p2在圆c1之"<<((locate(p2, c1)>0)?"外":((locate(p2, c1)<0)?"内":"上"))<<endl;

	cout<<"点p3: "<<p3;
	cout<<"点p3在圆c1之"<<((locate(p3, c1)>0)?"外":((locate(p3, c1)<0)?"内":"上"))<<endl;
	return 0;
}

(6)与圆心相连的直线:给定一点p,其与圆心相连成的直线,会和圆有两个交点,如图。在上面定义的Point(点)类和Circle(圆)类基础上,设计一种方案,输出这两点的坐标。

提示:

代码:

#include <iostream>
#include <cmath>
using namespace std;
class Circle;
class Point{
protected:
    double x,y;
public:
    Point(){x=0,y=0;}
    Point(double a,double b):x(a),y(b){}
    double getx(){return x;}
    double gety(){return y;}
    double distance(const Point& c){
        double dx = x-c.x;
        double dy = y-c.y;
        return sqrt(dx*dx+dy*dy);
    }
    friend istream&operator>>(istream& in,Point & c);
    friend ostream&operator<<(ostream& out,const Point& c);
    friend void fun(Circle &c, Point &p1);
};
istream& operator>>(istream& in,Point & c){
    cout<<"请输入点坐标(x,y)格式\n";
    char a,b,e;
    do{
        cin>>a>>c.x>>b>>c.y>>e;
        if(a=='('&&b==','&&e==')')
            break;
        cout<<"格式错误请重新输入!\n";
    } while(1);
    return in;
}
ostream& operator<<(ostream& out,const Point & c){
    cout<<"("<<c.x<<","<<c.y<<")\n";
    return out;
}
class Circle:public Point{
private:
    double r;
public:
    Circle():r(0){Point();}
    Circle(double a,double b,double c):Point(a,b),r(c){}
    friend istream&operator>>(istream& in,Circle & c);
    friend ostream&operator<<(ostream& out,const Circle& c);
    friend int locate(Point&,Circle&  );
    bool operator>(const Circle&);
    bool operator<(const Circle&);
    bool operator>=(const Circle&);
    bool operator<=(const Circle&);
    bool operator==(const Circle&);
    bool operator!=(const Circle&);
    friend void fun(Circle &c, Point &p1);
    double area(){
        return 3.14159*r*r;
    }
};
void fun(Circle &c, Point &p){
    Point p1,p2;
    p1.x = (c.x + sqrt(c.r*c.r/(1+((c.y-p.gety())/(c.x-p.getx()))*((c.y-p.gety())/(c.x-p.getx())))));
    p2.x = (c.x - sqrt(c.r*c.r/(1+((c.y-p.gety())/(c.x-p.getx()))*((c.y-p.gety())/(c.x-p.getx())))));
    p1.y = (p.gety() + (p1.x -p.getx())*(c.y-p.gety())/(c.x-p.getx()));
    p2.y = (p.gety() + (p2.x -p.gety())*(c.y-p.gety())/(c.x-p.getx()));
    cout<<"点p"<<p<<"与圆"<<c<<"相交于"<<p1<<"和"<<p2<<"两点\n";
}
bool Circle::operator>(const Circle& c){
    if(r>c.r)
        return true;
    return false;
}
bool Circle::operator<(const Circle& c){
    if(r<c.r)
        return true;
    return false;
}
bool Circle::operator>=(const Circle& c){
    if(r<c.r)
        return false;
    return true;
}
bool Circle::operator<=(const Circle& c){
    if(r>c.r)
        return false;
    return true;
}
bool Circle::operator==(const Circle& c){
    if(r==c.r)
        return true;
    return false;
}
bool Circle::operator!=(const Circle& c){
    if(r==c.r)
        return false;
    return true;
}
istream&operator>>(istream& in,Circle& c){
    Point d;
    cin>>d;
    c.x=d.getx();
    c.y=d.gety();
    cout<<"请输入半径:";
    cin>>c.r;
    return in;
}
ostream&operator<<(ostream& out,const Circle& c){
    cout<<"("<<c.x<<","<<c.y<<") 半径="<<c.r<<'\12';
    return out;
}
int locate(Point&t2,Circle&t1){
    Point t=t1;
    double x=t1.distance(t2);
    if (abs(x-t1.r)<1e-7)
        return 0;
    else if (x<t1.r)
        return -1;
    else
        return 1;
}
int main( ){
	Circle c1(3,2,4);
	Point p;
	cin>>p;
	fun(c1,p);
	return 0;
}

运行结果:

时间: 2024-10-10 03:11:36

第12周 【项目4 - 点、圆的关系】(3)的相关文章

第12周 项目四-点、园关系(1)(2)(3)

(1)先建立一个Point(点)类,包含数据成员x,y(坐标点): (2)以Point为基类,派生出一个Circle(圆)类,增加数据成员(半径),基类的成员表示圆心: (3)编写上述两类中的构造.析构函数及必要运算符重载函数(本项目主要是输入输出): 代码: #include <iostream> using namespace std; class Point { protected: int x; int y; public: Point(int a,int b):x(a),y(b){}

12周 项目4

最近一个问题很困扰我,今天则得到了答案,也意味着我该选择了. 不知道大家有没有遇到过这样的情况,我是上年刚毕业,大四时进行过java培训,12年9月-13年4月,在这之前已经自学过java.7月份时进入一家公司工作,今年3月份辞职,4月份找到工作,来上班了.一开始就不太喜欢公司氛围,前台,hr,态度什么的都不太好,工作环境也极像客服部,整天电话不断,讨论声不断,第一个星期真是煎熬,去了两三天之后有辞职的想法,但是后面想想还是算了,公司待遇还可以. 但是进入到公司后leader让学PHP,学PHP

12周 项目2 老师兼干部类

#include <iostream> #include <string> using namespace std; class Teacher { public: Teacher(string nam,int ag,char s,string ad,int num,string t) { name=nam; age=ag; sex=s; add=ad; number=num; title=t; } void display() { cout<<"name:

12周 项目3 摩托车继承机动车和自行车

#include <iostream> #include<conio.h> #include <windows.h> using namespace std; enum vehicleStaus {rest, running}; //车辆状态:泊车.行进 class vehicle //车辆类 { protected: int maxSpeed; //最大车速 int currentSpeed; //当前速度 int weight; //车重 vehicleStaus

第12周 项目四-点、圆关系(4)

(4)定义友元函数int locate,判断点p与圆的位置关系(返回值<0圆内,==0圆上,>0 圆外): int main( ) { Circle c1(3,2,4),c2(4,5,5); //c2应该大于c1 Point p1(1,1),p2(3,-2),p3(7,3); //分别位于c1内.上.外 cout<<"圆c1: "<<c1; cout<<"点p1: "<<p1; cout<<&q

第12周 项目四-点、圆关系(5)

(5)在圆类上重载关系运算符(6种),使之能够按圆的面积比较两个圆的大小.自编main函数完成测试. 代码: #include <iostream> using namespace std; class Circle; class Point { protected: int x; int y; public: Point(int a,int b):x(a),y(b) {} friend ostream &operator <<(ostream &out,Point

第十、十一周项目1 - 点-圆-圆柱类族的设计(2)

/* *Copyright (c) 2016,烟台大学计算机学院 *All rights reserved. *文件名称 : *作 者 : 徐聪 *完成日期 : 2016年5月9号 *版 本 号 : v1.0 *问题描述:以Point为基类,派生出一个Circle(圆)类,增加数据成员r(半径),以及求面积的成员函数area,实现其他需要的成员函数,设计main函数完成测试: */ #include<iostream> #include<cmath> using namespace

第十、十一周项目1 - 点-圆-圆柱类族的设计(3)

#include<iostream> #include<cmath> using namespace std; #define PI 3.1415926 class Point { public: void setPoint(float i,float j); float getX(){return x;} float getY(){return y;} float dr(Point &p1,Point &p2); private: float x; float y

第10周项目一-点-圆-圆柱类的设计

代码: /* *Copyright (c) 2016, 烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:main.cpp; *作 者:岳成艳2016年5月6号: *版 本 号:vc++6.0: * *问题描述:添加一个类cylinder类,增加数据成员函数h,求表面积,体积. *程序输入:略: *程序输出:略: */ #include <iostream> using namespace std; class Point { public: Point(d

第十、十一周项目一-点-圆-圆柱类族的设计(3)

<pre name="code" class="cpp">/* *Copyright(c)2016,烟台大学计算机与控制工程学院 *All rights reserved *文件名称:123.cpp *作 者:王蕊 *完成日期:2016年5月6日 *版 本 号:v1.0 * *问题描述:以点为基类,派生出一个圆类,增加数据成员r,和求面积的成员函数area,实现其他需要的成员函数,设计main函数完成测试. *输入描述:无. *程序输出:圆的圆心坐标,半