C++的救护车调度系统

2024-03-24 20:30
文章标签 c++ 系统 调度 救护车

本文主要是介绍C++的救护车调度系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++的救护车调度系统,很详细!

一、问题描述

某救护中心所在服务区有5辆救护车,当需要调度时,需要判定哪辆救护车是最优的,不同车辆的油箱容量(单位为公升)、燃油效率(单位为公里/公升)不同。
判定条件为:

(一)救护车中的燃料能够使救护车从当前位置行驶到待救护点,然后再行驶到救护中心;

(二)救护车距离待救护点最近(距离根据两点之间的距离公式计算,单位为公里);

(三)根据油箱中剩余的燃油量和燃油效率能够计算出救护车还能够行驶的里程数。

二、样例输入和样例输出

第1行输入救护中心的位置坐标(x y),用空格隔开;

第2~6行分别输入第1~5辆救护车的位置坐标(x y)、油箱容积、现有燃油量、燃油效率;

第7行输入待救护点的位置坐标(x y),用空格隔开;

如果能找到最优的救护车,则输出救护车的序号(从0开始)和其能够行驶的最大里程信息;

如果找不到满足条件的救护车,则输出“Scheduling Failure!”。

(一)样例输入

197.784 161.559

166.125 190.908 108 39.76 6.85

131.267 118.553 118 85.77 5.78

170.888 147.168 104 0.25 5.54

167.075 121.17 118 57.12 6.92

194.047 114.992 100 88.91 5.72

160.165 152.769

(二)样例输出

the Ambulance index = 0;the max Mileage = 272.356

三、代码实现

#include <bits/stdc++.h>using namespace std;#define AMNUMS 5
#define MAX_FLOAT 3.40282325E38
class point2d{
public:point2d(){};point2d(double x, double y){_x = x;_y = y;}double getX() const{return _x;}double getY() const{return _y;}void setx(double x){_x = x;}void sety(double y){_y = y;}
private:double _x = 0.0;double _y = 0.0;
};double getDistance(const point2d & pt1, const point2d & pt2){double dx = pt1.getX() - pt2.getX();double dy = pt1.getY() - pt2.getY();return sqrt(dx * dx + dy * dy);
}class Ambulance_car{
private:double m_lfCapcity;double m_lfRemain;double m_lfRatio;point2d m_curPosition;
public:Ambulance_car(){};void setcap(double cap){m_lfCapcity = cap;}void setrem(double rem){m_lfRemain = rem;}void setrat(double rat){m_lfRatio = rat;}void setPosition(point2d p){m_curPosition.setx(p.getX());m_curPosition.sety(p.getY());}double getcap(){return m_lfCapcity;}double getrem(){return m_lfRemain;}double getrat(){return m_lfRatio;}double getmaxx(){return getrat() * getrem();}point2d getpos(){return m_curPosition;}
};class EmergencyCenter{
private:point2d m_CenterPos;Ambulance_car m_arCar[AMNUMS];
public:EmergencyCenter(){};void setPosition(point2d p){m_CenterPos.setx(p.getX());m_CenterPos.sety(p.getY());}void setAmPosition(int i, point2d p){m_arCar[i].setPosition(p);}void setAmStatus(int i, double cap, double rem, double rat){m_arCar[i].setcap(cap);m_arCar[i].setrem(rem);m_arCar[i].setrat(rat);}double getAmmaxMileage(int i){return m_arCar[i].getmaxx();}int scheduling(const point2d & ptResecue){int id = -1;double max_dis = 1e18;for(int i = 0; i < AMNUMS; i++){double disa = getDistance(m_arCar[i].getpos(), ptResecue);double disb = getDistance(m_CenterPos, ptResecue);double max_meter = getAmmaxMileage(i);if(max_meter >= disa + disb){if(max_meter < max_dis){id = i;max_dis = max_meter;}}}return id;}
};int main()
{double Ifx,Ify;Ifx = Ify = 0.0;cin>>Ifx>>Ify;point2d pttemp(Ifx,Ify);EmergencyCenter emcenter;emcenter.setPosition(pttemp);double Ifcap,Ifrem,Ifrat;for(int i=0;i<AMNUMS;++i){cin>>Ifx>>Ify>>Ifcap>>Ifrem>>Ifrat;pttemp.setx(Ifx);pttemp.sety(Ify);emcenter.setAmPosition(i,pttemp);emcenter.setAmStatus(i,Ifcap,Ifrem,Ifrat);}cin>>Ifx>>Ify;pttemp.setx(Ifx);pttemp.sety(Ify);int nidx=emcenter.scheduling(pttemp);cout.flags(ios::fixed);cout.precision(3);if(nidx==-1){cout<<"Scheduling Failure!"<<endl;}else{cout<<"the Ambulance index="<<nidx<<";the max Mileage="<<emcenter.getAmmaxMileage(nidx)<<endl;}return 0;
}

四、程序运行结果

这篇关于C++的救护车调度系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/842690

相关文章

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性: