第十三周(项目三)——与圆心相连的直线。
来源:互联网 发布:linux终端运行w3m 编辑:程序博客网 时间:2024/05/12 20:25
/*02.*烟台大学计算机学院学生03.*All right reserved.04.*文件名称*烟台大学计算机学院学生05.*All right reserved.06.*文件名称:与圆心相连的直线07.*作者:王洪海08.*完成日期:2013年5月25日09.*版本号:v1.010.*对任务及求解方法的描述部分:与圆心相连的直线11.*我的程序:12.*/#include <iostream>#include <string>#include <cmath>using namespace std;class Circle; //由于在Point中声明友元函数crossover_point中参数中用了Circle,需要提前声明class Point{ protected: double x; double y; public: Point(double x0=0,double y0=0):x(x0),y(y0){} ~Point(){} double getx() { return x; } double gety() { return y; } friend ostream& operator <<(ostream &,Point &); friend void crossover_point(Point &p,Circle &c, Point &p1,Point &p2 );};ostream& operator <<(ostream &output,Point &p){ output<<"("<<p.x<<","<<p.y<<")"<<endl; return output;}class Circle:public Point{ protected: double r; public: Circle(double x0=0,double y0=0,double r0=0): Point(x0,y0),r(r0){} ~Circle(){} friend ostream& operator <<(ostream &,Circle &); friend void crossover_point(Point &p,Circle &c, Point &p1,Point &p2 );};ostream& operator <<(ostream &output,Circle &c){ output<<"圆心为:("<<c.x<<","<<c.y<<") 圆的半径为:"<<c.r<<endl; return output;}void crossover_point(Point &p,Circle &c, Point &p1,Point &p2 ){ p1.x = (c.x + sqrt(c.r*c.r/(1+((c.y-p.y)/(c.x-p.x))*((c.y-p.y)/(c.x-p.x))))); p2.x = (c.x - sqrt(c.r*c.r/(1+((c.y-p.y)/(c.x-p.x))*((c.y-p.y)/(c.x-p.x))))); p1.y = (p.y + (p1.x -p.x)*(c.y-p.y)/(c.x-p.x)); p2.y = (p.y + (p2.x -p.x)*(c.y-p.y)/(c.x-p.x));}int main( ){ Point p(1,1),p1,p2; Circle c(3,2,4); crossover_point(p,c,p1,p2); cout<<"点p: "<<p<<endl; cout<<"与圆c: "<<c<<endl; cout<<"的圆心相连,与圆交于两点,分别是:"<<endl; cout<<"交点1: "<<p1<<endl; cout<<"交点2: "<<p2<<endl; return 0;}
运行结果,如下图:
0 0
- 第十三周(项目三)——与圆心相连的直线。
- 第十三周项目三与圆心相连的直线
- 第十三周项目3-与圆心相连的直线
- 第十三周项目3--与圆心相连的直线
- 第十三周项目3--与圆心相连的直线 方案2
- 与圆心相连的直线
- 与圆心相连的直线
- 第十三周--圆外一点与圆心相连的直线与圆的交点
- 13【项目3 - 与圆心相连的直线】
- C++第13周(春)项目3 - 与圆心相连的直线
- 第13周(春)项目3 - 与圆心相连的直线
- 13.3输出给定一点p与圆心相连成的直线与圆的两个交点
- 第13周-与圆心连线的直线
- Matlab—动态绘制半径渐变的圆形与绕圆心旋转的直线
- 第十三周项目三——Dijkstra算法的验证
- 求过圆心直线与圆的两个交点(JAVA & OC)
- 求过圆心直线与圆的两个交点
- 求过圆心直线与圆的两个交点
- 用C语言的rand()和srand()产生伪随机数的方法总结
- Spring IOC--Bean的装配
- session的根本原理及安全性
- C# 窗体应用程序 之 单选按钮的实现 源代码
- LLMNR协议
- 第十三周(项目三)——与圆心相连的直线。
- python-lxml的系统依赖项
- 96. 必须在乎你的代码
- 笔记35--调用相机和相册
- 月球美容计划之最小生成树(MST)
- hdu_1062 Text Reverse(水题)
- C语言中static 和 extern用法
- 独木舟问题
- html5 返回当前地理位置的坐标点(经纬度)