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

相关文章

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示