本题自定义一个点类,类名Point,包含x轴坐标和y轴坐标,功能包括: 1)Set成员函数实现为点赋值; 2)Output成员函数实现输出点,格式为(x,y)(见输出样例); 3)GetX和GetY成员函数,分别返回x坐标和y坐标; 4)构造函数实现点的初始化,默认为原点(0,0)。 类的定义及主函数如下,请补充实现类的构造函数和成员函数。 类定义: class Point { public: Point(double xx=0,double yy=0); void Set(double xx,double yy); void Output(); double GetX() {return x; } double GetY() {return y; } private: double x,y; }; Point表示要定义的点类,包含x轴坐标和y轴坐标; 裁判测试程序样例: int main() { double m,n; cin >> m >> n; Point p1; p1.Output(); p1.Set(m,n); p1.Output(); Point p2(3,4); cout << p2.GetX() << "," << p2.GetY() << endl; return 0; } /* 请在这里填写Point定义的构造函数和成员函数(Set、Output)的答案

时间: 2024-01-26 17:01:39 浏览: 100
#include<iostream>
using namespace std;
class Point {
public:
    Point(double xx = 0, double yy = 0) {
        x = xx;
        y = yy;
    }
    void Set(double xx, double yy) {
        x = xx;
        y = yy;
    }
    void Output() {
        cout << "(" << x << "," << y << ")" << " ";
    }
    double GetX() { return x; }
    double GetY() { return y; }
private:
    double x, y;
};
int main() {
    double m, n;
    cin >> m >> n;
    Point p1;
    p1.Output();
    p1.Set(m, n);
    p1.Output();
    Point p2(3, 4);
    cout << p2.GetX() << "," << p2.GetY() << endl;
    return 0;
}
相关问题

自定义Point类实现点的定义及两点间函数的功能 分数 10 作者 陈春丽 单位 中国地质大学(北京) 本题实现自定义一个点类,类名Point,包含x轴坐标和y轴坐标,功能包括: 1)Set成员函数实现为点赋值; 2)Output成员函数实现输出点,格式为(x,y)(见输出样例); 3)GetX和GetY成员函数,分别返回x坐标和y坐标; 4)构造函数实现点的初始化,默认为原点(0,0); 5)两个点之间的距离,已知两个点p1(x1,y1)和p2(x2,y2)间的距离公式为: (x1−x2)

下面是自定义Point类的代码:

import math

class Point:
    def __init__(self, x=0, y=0):
        self.x = x
        self.y = y
        
    def set(self, x, y):
        self.x = x
        self.y = y
        
    def output(self):
        print("({}, {})".format(self.x, self.y))
        
    def get_x(self):
        return self.x
    
    def get_y(self):
        return self.y
    
    def distance(self, other):
        dx = self.x - other.x
        dy = self.y - other.y
        return math.sqrt(dx ** 2 + dy ** 2)

使用方法如下:

# 创建两个点对象
p1 = Point()
p2 = Point()

# 设置p1的坐标为(1, 2)
p1.set(1, 2)

# 输出p1的坐标
print("p1的坐标为:", end="")
p1.output()  # 输出:(1, 2)

# 获取p2的坐标
x, y = 3, 4
p2.set(x, y)
print("p2的坐标为:({}, {})".format(p2.get_x(), p2.get_y()))  # 输出:p2的坐标为:(3, 4)

# 计算p1和p2之间的距离
d = p1.distance(p2)
print("p1和p2之间的距离是:", d)  # 输出:p1和p2之间的距离是:2.8284271247461903

注意,以上代码使用了数学库中的math.sqrt()函数来计算平方根。

6-6 自定义函数求两点间距离(点是自定义Point类) 分数 10 全屏浏览题目 切换布局 作者 陈春丽 单位 中国地质大学(北京) 本题实现两个点之间的距离的函数,已知两个点p1(x1,y1)和p2(x2,y2)间的距离公式为: (x1−x2) 2 +(y1−y2) 2 ​ 。 自定义一个点类,类名Point,包含x轴坐标和y轴坐标,功能包括: 1)Set成员函数实现为点赋值; 2)Output成员函数实现输出点,格式为(x,y)(见输出样例); 3)GetX和GetY成员函数,分别返回x坐标和y坐标; 4)构造函数实现点的初始化,默认为原点(0,0)。 类的定义及主函数如下,请补充实现类的构造函数和成员函数,以及getDis函数实现两点间距离。 类及函数接口定义: class Point { public: Point(double xx=0,double yy=0); void Set(double xx,double yy); void Output(); double GetX() {return x; } double GetY() {return y; } private: double x,y; }; double getDis(Point &p1, Point &p2); `getDis`函数返回`Point`类型的两个对象p1和p2之间的距离(`double`型) `p1`是`Point`类型的引用对象,即实参`Point`对象的引用(别名),`p2`类似 裁判测试程序样例: int main() { double x1,y1,x2,y2; cin >> x1 >> y1 >> x2 >> y2; Point p1; p1.Set(x1,y1); p1.Output(); Point p2(x2,y2); p2.Output(); cout << "distance=" << getDis(p1,p2) << endl; return 0; } /* 请在这里填写Point定义的构造函数和成员函数(Set、Output),以及普通函数getDis的答案 */ /* 答案区共4个函数定义,无其它内容*/

#include <iostream>
#include <cmath>
using namespace std;

class Point {
public:
    Point(double xx=0,double yy=0) {
        x = xx;
        y = yy;
    }
    void Set(double xx,double yy) {
        x = xx;
        y = yy;
    }
    void Output() {
        cout << "(" << x << "," << y << ")";
    }
    double GetX() {return x;}
    double GetY() {return y;}
private:
    double x,y;
};

double getDis(Point &amp;p1, Point &amp;p2) {
    double dis = sqrt(pow(p1.GetX()-p2.GetX(), 2) + pow(p1.GetY()-p2.GetY(), 2));
    return dis;
}

int main() {
    double x1,y1,x2,y2;
    cin >> x1 >> y1 >> x2 >> y2;
    Point p1;
    p1.Set(x1,y1);
    p1.Output();
    Point p2(x2,y2);
    p2.Output();
    cout << "distance=" << getDis(p1,p2) << endl;
    return 0;
}
向AI提问 loading 发送消息图标

相关推荐

zip
内容概要:本文介绍了一款国内首家推出的车载DC/DC转换器解决方案,旨在解决传统电源方案的诸多痛并助力车载电源智能化升级。硬件设计方面,采用TI C2000系列主控芯片,搭配进口功率器件和高精度采样电路,提供了高可靠性的电源方案,甚至将输入级EMI滤波部分进行了模块化设计,并给出了不同功率等级下的元器件选型表。软件部分实现了电压环、电流环双闭环控制,采用了动态调整算法,创新地使用DMA搬运PWM占空比参数,降低CPU占用率,同时在输入电压异常时自动切换硬件保护模式。上位机工具提供实时数据显示、参数设置、波形分析等功能,开放了协议栈源码,内置自动标定功能。; 适合人群:从事车载电源开发的工程师,尤其是希望提升产品开发效率和技术水平的专业人士。; 使用场景及目标:①硬件工程师可以借鉴模块化设计思路和详细的元器件选型表,优化电路设计;②软件工程师可以从双闭环控制算法、DMA传输机制等方面学习先进的编程技巧;③调试人员利用上位机工具进行便捷高效的参数调整和故障排查。; 其他说明:该方案不仅提供了完整的技术文档支持,而且开放的软件架构和配套调试工具极大地方便了二次开发,提高了开发效率。建议对车载电源开发感兴趣的工程师获取相关资料深入学习。
docx
内容概要:本文档是为华为C语言面试设计的试卷,旨在评估应聘者的C语言掌握程度。试卷分为三个主要部分:选择题、填空题和代码题。选择题涵盖了基础语法、指针、内存管理、数据结构等核心知识,例如动态内存分配、指针操作、结构体大小、位运算等。填空题进一步考察了指针、函数声明、宏定义、内存管理等实际编程技能。代码题则侧重于算法实现包括单链表反转、字符串逆序、二分查找、内存拷贝、统计二进制中1的个数、删除链表节、快速排序、判断回文链表、大端小端检测以及线程安全单例模式的实现。所有题目难度适中且贴近实际开发场景,有助于全面评估应聘者的编程能力和问题解决能力。; 适合人群:具备一定C语言基础,有志于应聘华为或其他相关企业的软件开发岗位的求职者。; 使用场景及目标:①帮助求职者复习C语言基础知识,熟悉常的面试考;②通过实际编程题目的练习,提高解决问题的能力;③模拟真实面试环境,提升面试自信心。; 其他说明:此试卷不仅测试应聘者的理论知识,还注重实际编程能力的考察。建议考生在准备过程中,不仅要掌握语法和概念,还要多动手实践,理解每个知识的具体应用。同时,注意代码的规范性和鲁棒性,确保在面试中能够写出高质量的代码。
大学生入口

最新推荐

recommend-type

C++获取类的成员函数的函数指针详解及实例代码

虚函数在派生类中可以被重写,因此其函数指针存储的是虚函数表(vtable)中的一个偏移值,以实现多态性。声明一个虚成员函数指针类似: ```cpp void(A::*ptrvirtual)() = &A::virtualmember; ``` 调用虚函数...
recommend-type

Java自定义函数调用方法解析

本文将通过详细的示例代码,介绍Java自定义函数调用方法解析的主要内容,包括在主类中自定义函数、自定义类中函数的调用等。 一、主类中自定义函数的调用 在主类中,如果想要在main函数中调用自定义的其他方法,则...
recommend-type

毕业设计物联网实战项目基于Eclipse Theia开源框架开发的物联网在线编程IDE.zip

【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
recommend-type

工具变量-全国分省低空经济高质量发展数据(2012-2023年)

因文件较多,数据存放网盘,txt文件内包含下载链接及提取码,永久有效。失效会第一时间进行补充。样例数据及详细介绍参见文章:https://blog.csdn.net/T0620514/article/details/146960240
recommend-type

【ThingsBoard初体验】本地编译踩坑记录.html

【ThingsBoard初体验】本地编译踩坑记录.html
recommend-type

全面解析DDS信号发生器:原理与设计教程

DDS信号发生器,即直接数字合成(Direct Digital Synthesis,简称DDS)信号发生器,是一种利用数字技术产生的信号源。与传统的模拟信号发生器相比,DDS信号发生器具有频率转换速度快、频率分辨率高、输出波形稳定等优势。DDS信号发生器广泛应用于雷达、通信、电子测量和测试设备等领域。 DDS信号发生器的工作原理基于相位累加器、正弦查找表、数字模拟转换器(DAC)和低通滤波器的设计。首先,由相位累加器产生一个线性相位增量序列,该序列的数值对应于输出波形的一个周期内的相位。通过一个正弦查找表(通常存储在只读存储器ROM中),将这些相位值转换为相应的波形幅度值。之后,通过DAC将数字信号转换为模拟信号。最后,低通滤波器将DAC的输出信号中的高频分量滤除,以得到平滑的模拟波形。 具体知识点如下: 1. 相位累加器:相位累加器是DDS的核心部件之一,负责在每个时钟周期接收一个频率控制字,将频率控制字累加到当前的相位值上,产生新的相位值。相位累加器的位数决定了输出波形的频率分辨率,位数越多,输出频率的精度越高,可产生的频率范围越广。 2. 正弦查找表(正弦波查找表):正弦查找表用于将相位累加器输出的相位值转换成对应的正弦波形的幅度值。正弦查找表是预先计算好的正弦波形样本值,通常存放在ROM中,当相位累加器输出一个相位值时,ROM根据该相位值输出相应的幅度值。 3. 数字模拟转换器(DAC):DAC的作用是将数字信号转换为模拟信号。在DDS中,DAC将正弦查找表输出的离散的数字幅度值转换为连续的模拟信号。 4. 低通滤波器:由于DAC的输出含有高频成分,因此需要通过一个低通滤波器来滤除这些不需要的高频分量,只允许基波信号通过,从而得到平滑的正弦波输出。 5. 频率控制字:在DDS中,频率控制字用于设定输出信号的频率。频率控制字的大小决定了相位累加器累加的速度,进而影响输出波形的频率。 6. DDS设计过程:设计DDS信号发生器时,需要确定信号发生器的技术指标,如输出频率范围、频率分辨率、相位噪声、杂散等,然后选择合适的电路器件和参数。设计过程通常包括相位累加器设计、正弦查找表生成、DAC选择、滤波器设计等关键步骤。 毕业设计的同学在使用这些资料时,可以学习到DDS信号发生器的设计方法和优化策略,掌握如何从理论知识到实际工程应用的转换。这些资料不仅有助于他们完成毕业设计项目,还能为将来从事电子工程工作打下坚实的基础。
recommend-type

【联想LenovoThinkServer TS80X新手必读】:企业级服务器快速入门指南(内含独家秘诀)

# 摘要 本文对联想Lenovo ThinkServer TS80X服务器进行了全面介绍,涵盖了硬件基础、系统配置、网络安全、维护扩展以及未来展望等关键领域。首先,概述了该服务器的主要硬件组件和物理架构,特别强调了联想ThinkServer TS80X的特色架构设计。接着,详细阐述了系统安装与配置过程中的关键步骤和优化策略,以及网络配置与安全管理的实践。本文还讨论了
recommend-type

ubuntu anaconda opencv

### 安装并配置 OpenCV 使用 Anaconda 的方法 在 Ubuntu 上通过 Anaconda 安装和配置 OpenCV 是一种高效且稳定的方式。以下是详细的说明: #### 方法一:通过 Conda 渠道安装 OpenCV 可以直接从 `conda-forge` 频道安装 OpenCV,这是最简单的方法之一。 运行以下命令来安装 OpenCV: ```bash conda install -c conda-forge opencv ``` 此命令会自动处理依赖关系并将 OpenCV 安装到当前激活的环境之中[^1]。 --- #### 方法二:手动编译安装 Open
recommend-type

掌握VC++图像处理:杨淑莹教材深度解析

根据提供的文件信息,本文将详细解读《VC++图像处理程序设计》这本书籍的相关知识点。 ### 标题知识点 《VC++图像处理程序设计》是一本专注于利用C++语言进行图像处理的教程书籍。该书的标题暗示了以下几个关键点: 1. **VC++**:这里的VC++指的是Microsoft Visual C++,是微软公司推出的一个集成开发环境(IDE),它包括了一个强大的编译器、调试工具和其他工具,用于Windows平台的C++开发。VC++在程序设计领域具有重要地位,尤其是在桌面应用程序开发和系统编程中。 2. **图像处理程序设计**:图像处理是一门处理图像数据,以改善其质量或提取有用信息的技术学科。本书的主要内容将围绕图像处理算法、图像分析、图像增强、特征提取等方面展开。 3. **作者**:杨淑莹,作为本书的作者,她将根据自己在图像处理领域的研究和教学经验,为读者提供专业的指导和实践案例。 ### 描述知识点 描述中提到的几点关键信息包括: 1. **教材的稀缺性**:本书是一本较为罕见的、专注于C++语言进行图像处理的教材。在当前的教材市场中,许多图像处理教程可能更倾向于使用MATLAB语言,因为MATLAB在该领域具有较易上手的特点,尤其对于没有编程基础的初学者来说,MATLAB提供的丰富函数和工具箱使得学习图像处理更加直观和简单。 2. **C++语言的优势**:C++是一种高性能的编程语言,支持面向对象编程、泛型编程等高级编程范式,非常适合开发复杂的软件系统。在图像处理领域,C++可以实现高效的算法实现,尤其是在需要处理大量数据和优化算法性能的场合。 3. **针对初学者和有一定编程基础的人士**:这本书虽然使用了相对复杂的C++语言,但仍然适合编程初学者,尤其是那些已经具备一定编程基础的读者,如理工科院校的学生、图像处理的爱好者和工程师。 ### 标签知识点 标签与标题相呼应,指出了书籍的特色和研究领域: 1. **VC++**:标签强化了该书使用VC++这一工具进行开发的特点。 2. **图像处理程序设计**:标签强调了本书内容的重点在于图像处理程序的设计与实现。 3. **杨淑莹**:作为标签的一部分,作者的名字体现了本书的专业性和作者的学术地位。 ### 压缩包子文件的文件名称列表 1. **VC++图像处理程序设计(杨淑莹).pdf**:这个文件名称告诉我们,下载的文件是PDF格式的,且文件内容与《VC++图像处理程序设计》这本书籍相关,作者是杨淑莹。 总结以上知识点,这本书籍对于熟悉C++语言并希望深入学习图像处理技术的读者来说,是一个宝贵的资源。书中可能会详细地介绍如何使用C++语言结合VC++的开发环境进行各种图像处理任务,包括但不限于:图像的读取与显示、颜色转换、图像滤波、边缘检测、图像分割、形态学处理、特征提取以及图像识别等方面。此外,鉴于图像处理领域涉及到大量的数学知识,如线性代数、概率论和数值分析等,本书可能还会包含这些基础理论知识的介绍,以帮助读者更好地理解和实现图像处理算法。
recommend-type

【ant.jar应用详解】:Java中高效解压ZIP文件的策略

# 摘要 本文详细介绍了ant.jar在ZIP文件解压中的应用,从基本API概述到性能优化,再扩展到与Java NIO的结合使用。通过分析ant.jar的主要组件和解压相关的类,本文演示了如何利用ant.jar执行基本和高级解压操作,并对异常情况进行处理。接着,文章探讨了如何将ant.jar与Java NIO技术相结合来提升解压效率,并展示了异步解压
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部