c++第六次实验-两点距离
来源:互联网 发布:c语言less 编辑:程序博客网 时间:2024/06/05 04:54
一、问题及代码
/* 文件名称:项目2.cpp* 作 者:严明远* 完成日期:2017 年 5 月 20 日* 版 本 号:v1.0* 对任务及求解方法的描述部分:* 输入描述:无* 问题描述:求两点间距离* 算法设计:略*/#include<iostream>#include<cmath>using namespace std;class CPoint{public:CPoint(double xx=0,double yy=0);double Distance1(CPoint p) const; //两点之间距离double Distance0() const; //到原点的距离CPoint Sy(char style) const; //返回对称点void input(); //以x,y形式输出坐标点void output(); //以(x,y)形式输出坐标点private:double x,y;};CPoint::CPoint(double xx,double yy){x=xx;y=yy;}void CPoint::input(){char ch;cout<<"请输入坐标点格式(x,y)";while(1){cin>>x>>ch>>y;if(ch==',')break;cout<<"输入的格式不规范,请重新输入。"<<endl;}}void CPoint::output(){cout<<"("<<x<<","<<y<<")"<<endl;}double CPoint::Distance1(CPoint p) const{double d;d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));return d;}double CPoint::Distance0() const{double d;d=sqrt(x*x+y*y);return d;}CPoint CPoint::Sy(char style) const{ CPoint p(this->x,this->y);//用复制构造函数时,写作p(*this) switch(style) { case 'x': p.y=-y; break; case 'y': p.x=-x; break; case '0': p.x=-x;p.y=-y; } return p;}int main(){ double distance; CPoint p1,p2,p; cout<<"第1个点p1,"; p1.input(); cout<<"第2个点p2,"; p2.input(); distance=p1.Distance1(p2); cout<<"两点的距离为:"<<distance<<endl; distance=p1.Distance0(); cout<<"p1到原点的距离为:"<<distance<<endl; p=p1.Sy('x'); cout<<"p1关于x轴的对称点为:"; p.output(); p=p1.Sy('y'); cout<<"p1关于y轴的对称点为:"; p.output(); p=p1.Sy('o'); cout<<"p1关于原点的对称点为:"; p.output();return 0;}
阅读全文
0 0
- c++第六次实验-两点距离
- C++第1次实验-两点距离
- C++第1次实验-两点距离
- C++第2次实验-两点距离
- C++第1次实验-两点距离
- C++第2次实验—两点距离
- C++第1次实验【项目3】两点距离
- 第六周实验报告任务 3 两点之间距离
- C语言第六次上机实验
- C++实验2-两点距离
- c++实验2-两点距离
- C++第一次实验:两点距离
- 第二次c++实验:两点距离
- C++第一次实验:两点距离
- C++第1次实验(提高班)项目三:两点距离
- 第六周实验指导--任务3--设计平面坐标点类,计算两点之间距离
- 第六次c++实验
- 第六次实验
- github 下载的zip项目如何再关联回去
- 如何写一份好的求职简历
- 简明C语言教程(十六)数组概述
- 交换两个兄弟元素的位置
- js 中的四舍五入
- c++第六次实验-两点距离
- 简明C语言教程(十七)函数
- Centos7安装Jenkins
- 三个数组随机合并
- [leetcode]: 70. Climbing Stairs
- LeetCode: Word Search
- 简明C语言教程(十九)变量的作用域和存储方式
- Linux安装后要做的事
- 思维的局限