贪心应用--汽车加油次数问题

文章目录

    • 1. 问题描述
    • 2. 解题思路
    • 3. 实现代码
    • 4. 测试结果

1. 问题描述

已知汽车的油箱额定里程,到目的地的路途中各加油站距起点的距离,求如何加油,让加油的次数最少。

2. 解题思路

  • 每次出发前检查下一个加油站有多远,车子能不能跑得到
  • 能到,就不加油
  • 不能到,就加油
  • 如果加了油,还不能到,说明不能到达目的地

3. 实现代码

/*** @description: 已知路上各加油站的距离,求最少加油次数(贪心)* @author: michael ming* @date: 2019/7/3 18:07* @modified by: */
#include <iostream>
#define N 9     //加油站个数
#define oil_volume 10    //油箱额定可跑里程
using namespace std;
class Car
{
public:int s;//行驶里程int carmileage;//油箱可跑里程Car():s(0),carmileage(oil_volume){}void fillgas(){carmileage = oil_volume;//加油,油箱加满}
};
int main()
{Car tesla;int gasStation[N] = {10,20,35,40,50,65,75,85,100};//加油站距离起点距离int dist, i = 0;bool fill = true;//加油了吗,默认加满了油出发cout << "请输入目的地的距离:";cin >> dist;if(tesla.carmileage >= dist)cout << "无需加油," << "剩余的汽油可跑"<< tesla.carmileage-dist << "km。" << endl;else{for(i = 0; i < N; ++i){if(tesla.s + tesla.carmileage >= gasStation[i])//车子可开到i加油站{tesla.carmileage -= gasStation[i]-tesla.s;//油箱变少tesla.s = gasStation[i];//里程更新fill = false;//没有加油if(tesla.s >= dist){cout << "到达终点,剩余的汽油可跑"<< tesla.carmileage+tesla.s-dist << "km。" << endl;break;}}else if(tesla.s + tesla.carmileage < gasStation[i] && !fill){//车子没有加油,到不了i号加油站,需要在i-1站加油i--;//i-1站tesla.fillgas();//加油fill = true;//标记加过油cout << "在" << gasStation[i] << "km处加油!" << endl;}else//车子前一站加过油,还到不了i号加油站,不能到达目的地{cout << "不能到达目的地,距离目的地" << dist-(tesla.s+tesla.carmileage)<< "km,距离下一个加油站" << gasStation[i]-(tesla.s+tesla.carmileage)<< "km,请呼叫救援!"<< endl;break;}}if(tesla.s < dist && i >= N)//开过了所有的加油站 还没到cout << "不能到达目的地,后面没有加油站,距离目的地"<< dist-(tesla.s+tesla.carmileage) << "km,请呼叫救援!"<< endl;}return 0;
}

4. 测试结果

int gasStation[N] = {10,20,35,40,50,65,75,85,100};//加油站距离起点距离
#define oil_volume 10    //油箱额定可跑里程

在这里插入图片描述

#define oil_volume 20    //油箱额定可跑里程

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/480150.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最全多线程经典面试题和答案

Java实现线程有哪几种方式&#xff1f; 1、继承Thread类实现多线程2、实现Runnable接口方式实现多线程3、使用ExecutorService、Callable、Future实现有返回结果的多线程 多线程同步有哪几种方法&#xff1f; Synchronized关键字&#xff0c;Lock锁实现&#xff0c;分布式锁等…

论文浅尝 | Aligning Knowledge Base and Document Embedding Models

本文是我们于苏黎世大学合作的关注与知识图谱和文本对齐的论文&#xff0c;发表于ISWC2018.文本和知识图谱都包含了丰富的信息, 其中知识图谱用结构化的三元组表示信息&#xff0c;文本用自由文本形式表示信息&#xff0c;信息表示的差异给知识图谱和文本融合对齐造成了困难&am…

学会提问的BERT:端到端地从篇章中构建问答对

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林机器阅读理解任务&#xff0c;相比不少读者都有所了解了&#xff0c;简单来说就是从给定篇章中寻找给定问题的答案&#xff0c;即“篇章 问题 → 答案”这样的流程&#xff0c;笔者之前也写过一些…

玩转算法面试-第四章查找值之leetcod相关笔记

查找问题 4-1,2 两类查找问题 1 查找有无&#xff1a;set 2 查找对应关系&#xff1a;map 常见的四种操作&#xff1a; insert&#xff0c; find&#xff0c; erase&#xff0c; change&#xff08;map&#xff09; 例题 leetcode 349 &#xff1a;给定两个数组&#xff0c;…

分治算法(Divide Conquer)

文章目录1. 分治算法思想2. 应用举例2.1 逆序度3. 分治思想处理海量数据1. 分治算法思想 分治算法的核心思想就是&#xff0c;分而治之&#xff0c;将原问题划分成n个规模较小&#xff0c;并且结构与原问题相似的子问题&#xff0c;递归地解决这些子问题&#xff0c;然后再合并…

史上最全Java多线程面试60题,含答案大赠送!

【BAT必考系列&#xff01;多线程60题】 多线程有什么用&#xff1f; 线程和进程的区别是什么&#xff1f; ava实现线程有哪几种方式&#xff1f; 启动线程方法start&#xff08;&#xff09;和run&#xff08;&#xff09;有什么区别&#xff1f; 怎么终止一个线程&#…

论文浅尝 | Interaction Embeddings for Prediction and Explanation

本文是我们与苏黎世大学合作的工作&#xff0c;将发表于WSDM2019&#xff0c;这篇工作在知识图谱的表示学习中考虑了实体和关系的交叉交互&#xff0c;并且从预测准确性和可解释性两个方面评估了表示学习结果的好坏。给定知识图谱和一个要预测的三元组的头实体和关系&#xff0…

商汤科技-数据运维工程师-提前批笔试题目汇总

2019年8月19日 问答题1&#xff1a;缺失值数据预处理有哪些方法&#xff1f;https://juejin.im/post/5b5c4e6c6fb9a04f90791e0c 处理缺失值的方法如下&#xff1a;删除记录&#xff0c;数据填补和不处理。主要以数据填补为主。 1 删除记录&#xff1a;该种方法在样本数据量十分…

秋招视频攻略!13个offer,8家SSP的Q神谈算法岗秋招技巧

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术大家还记得几个月前卖萌屋Q神推送的那期《13个offer&#xff0c;8家SSP&#xff0c;谈谈我的秋招经验》吗&#xff1f;据说Q神掌握了影分身的话&#xff0c;一毕业就能年薪600万&#xff0c;咳咳。。。ps&…

分治应用--最近点对问题 POJ 3714

文章目录1. 问题描述2. 解题思路3. 实现代码4. POJ 37141. 问题描述 二维平面上有n个点&#xff0c;如何快速计算出两个距离最近的点对&#xff1f; 2. 解题思路 暴力做法是&#xff0c;每个点与其他点去计算距离&#xff0c;取最小的出来&#xff0c;复杂度O(n2)采用分治算…

Java多线程系列(十):源码剖析AQS的实现原理

在并发编程领域&#xff0c;AQS号称是并发同步组件的基石&#xff0c;很多并发同步组件都是基于AQS实现&#xff0c;所以想掌握好高并发编程&#xff0c;你需要掌握好AQS。 本篇主要通过对AQS的实现原理、数据模型、资源共享方式、获取锁的过程&#xff0c;让你对AQS的整体设计…

玩转二算法课的笔记-第一章

1 问题&#xff1a;对一组数据进行排序 回答&#xff1a;快速排序算法o(NLOGN)&#xff0c;错误。 关键词&#xff1a;思考 应该问面试官&#xff0c;这组数据有什么样的特征&#xff1f; 比如;有没有可能包含大量重复的元素&#xff1f; 如果有这个可能的话&#xff0c;三路快…

微软亚洲研究院NLC组招聘实习生!与一线研究员共探NLP前沿与落地!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术MSRA-NLC组招人啦&#xff01;微软亚洲研究院&#xff08;MSRA&#xff09;自然语言计算组&#xff08;NLC&#xff09;招收长期实习生一名&#xff0c;与一线研究员共同进行自然语言处理领域的科研项目和落地…

分治应用--万里挑一 找假硬币

文章目录1. 问题描述2. 解题思路3. 代码实现1. 问题描述 n 个硬币中有1枚是假币&#xff0c;真假币唯一的区别是假币重量轻&#xff0c;如何快速找出假币 2. 解题思路 暴力做法&#xff0c;一个一个的称重&#xff0c;O&#xff08;n&#xff09;复杂度分治思路 将硬币等分…

Java多线程与并发系列从0到1全部合集,强烈建议收藏!

在过去的时间中&#xff0c;我写过Java多线程与并发的整个系列。 为了方便大家的阅读&#xff0c;也为了让知识更系统化&#xff0c;这里我单独把Java多线程与并发的整个系列一并罗列于此&#xff0c;希望对有用的人有用&#xff0c;也希望能帮助到更多的人。 以下为整个目录&a…

论文浅尝 | 基于图注意力的常识对话生成

OpenKG 祝各位读者新春快乐&#xff0c;猪年吉祥&#xff01;来源&#xff1a;IJCAI 2018.论文下载地址&#xff1a;https://www.ijcai.org/proceedings/2018/0643.pdf项目源码地址&#xff1a;https://github.com/tuxchow/ccm动机在以前的工作中&#xff0c;对话生成的信息源是…

Facebook、阿里等大佬现身说法,NLP是否被高估了?

NLP (自然语言处理)&#xff0c;利用计算机对人类的语言文字进行处理。由于语言文字是人类交流沟通的最基本方式&#xff0c;因此 NLP 也是最典型的 AI 领域之一。NLP 被誉为“人工智能皇冠上的明珠”。这话也许没错&#xff0c;但听起来难免空洞。所以我去实际问了3位从事 NLP…

玩转算法面试-第二章

1 时间复杂度分析 正常处理的数据规模&#xff0c;为了保险起见&#xff0c;可将将上面的数在除以10&#xff0c;防止电脑假死。 空间复杂度分析&#xff1a; 注意问题&#xff1a;递归调用是有空间代价的 3 常见的复杂度分析 翻转的代码&#xff1a; 选择排序的方法&a…

论文笔记(Attentive Recurrent Social Recommendation)

注意力循环社交推荐 原文链接&#xff1a;Attentive Recurrent Social Recommendation, SIGIR’18 原理&#xff1a;将用户的朋友和历史交互项按时间划分&#xff0c;用注意力机制整合各个时段的朋友影响和交互项影响后输入LSTM来学习动态用户向量&#xff0c;动态用户向量与动…

回溯算法(Backtracking Algorithm)之八皇后问题

文章目录1. 回溯算法思想2. 算法应用2.1 八皇后问题1. 回溯算法思想 前面讲过贪心算法并不能保证得到最优解&#xff0c;那怎么得到最优解呢&#xff1f; 回溯思想&#xff0c;有点类似枚举搜索。枚举所有的解&#xff0c;找到满足期望的解。为了有规律地枚举所有可能的解&am…