java 旅行家的预算_洛谷 P1016 旅行家的预算 Java解法

洛谷 P1016 旅行家的预算 Java解法

洛谷 P1016 旅行家的预算 Java解法

9e5180eea8ab610b45ac6d023cdcef26.png

package com.two;

import java.util.Scanner;

public class Main {

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

double D1 = sc.nextDouble();// 两个城市之间的距离

double C = sc.nextDouble();// 汽车油箱中油的容量

double D2 = sc.nextDouble();// 每升汽油能行驶的距离

double P = sc.nextDouble();// 出发时每升汽油的价格

int N = sc.nextInt();// 沿途油站数

double distance[] = new double[N + 2];// 距离加油站的路程

double Pi[] = new double[N + 2]; // 每个加油站汽油的价格

double Maxd = D2 * C;// 目前油箱中油所能跑的最大距离

double money = 0;// 需要的钱

double surplus = 0;// 油箱中在到达了下一个加油站时油箱中的剩余油量

// 初始化距离和油价数组,且起点和终点也加进去

distance[0] = 0;

Pi[0] = P;

distance[N + 1] = D1;

Pi[N + 1] = 0;

for (int i = 1; i <= N; i++) {

distance[i] = sc.nextDouble();

Pi[i] = sc.nextDouble();

}

// 当油箱中油用完所能走的距离小于两个加油站之间的距离时无解

for (int i = 0; i <= N; i++) {

if (distance[i + 1] - distance[i] > Maxd) {

System.out.println("No Solution");

return;

}

}

// 有解,开始遍历每一个站点

int i = 0;

while (i <= N) {

int j;

for (j = i + 1; j <= N + 1; j++) {// 下一个

if (distance[j] - distance[i] > Maxd) {

j = j - 1;// 最大行驶距离无法到达j,因此最大到达j-1站点

break;

}

if (Pi[j] <= Pi[i]) {// 找到下一个更便宜的加油站

break;

}

}

// 更新油费:{距离下一站的路程/每升汽油能行驶的距离-油箱中的剩余油量)}*上一个加油站的油的价格 ;

// 钱=量*单价

if (Pi[j] <= Pi[i]) {// 找到下一个更便宜的加油站

money += ((distance[j] - distance[i]) / D2 - surplus) * Pi[i];

surplus = 0;// 更新到达下一个加油站后的剩余油量

} else {// 否则没有找到比这个加油站便宜的油,则加满油

money += (C - surplus) * Pi[i];// (油箱容量-剩余油)*每升油的单价

surplus = C - (distance[j] - distance[i]) / D2;// 剩余油量=(油箱容量-相邻一站耗的油)/每升汽油行驶的距离

}

i = j;// 往下一个加油站行驶

}

System.out.println(String.format("%.2f", money));

}

}

洛谷 P1016 旅行家的预算 Java解法相关教程

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

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

相关文章

java语言执行过程_Java程序的运行过程(执行流程)分析

万事知其然&#xff0c;要知其所以然&#xff0c;所以本节带大家来详细了解一下 Java 程序的执行过程。从《使用记事本编写运行Java程序》一节的案例可以看出&#xff0c;Java 程序的运行必须经过编写、编译和运行 3 个步骤。编写&#xff1a;是指在 Java 开发环境中进行程序代…

php搭建云服务器,云服务器上如何搭建php环境

1) 安装libtool和libtool-ltdl[rootlocalhost mysql]# yum -y install "libtool*"[rootlocalhost mysql]# yum -y install "libtool-ltdl*"2) 手工修改gd库文件PHP 5.4 也有一些 Bug&#xff0c;在检测 gd 库时会报错&#xff0c;需要我们手工修改。命令如…

php实现文本替换,php 如何实现文字替换

php实现文字替换的方法&#xff1a;首先创建一个PHP示例文件&#xff1b;然后输入代码“str_replace("iwind", "kiki", "i love iwind, iwind said");”&#xff1b;最后输出执行结果即可。在php替换字符效率最高也是最简单字符替换函数str_repl…

php 删除指定html标签,php删除html标签的三种解决办法

分享下PHP删除HTMl标签的三种方法。方法1&#xff1a;直接取出想要取出的标记function strip($str){$strstr_replace("","",$str);//$strhtmlspecialchars($str);return strip_tags($str);}//edit by www.jbxue.com?>方法2.PHP 中有个 strip_tags 函数…

达内php第三次月考,达内第三次月考

1. 下列不属于浏览器内置的对象的是&#xff1a;()A. navigatorB. documentC. windowD. request正确答案&#xff1a;D2. Servlet 可以存储数据的三个不同的作用域是()。A. 请求、会话和上下文B. 响应、会话和上下文C. 请求、响应和会话D. 请求、响应和上下文正确答案&#xff…

java win10 通知,如何使用Java AWT创建和显示Windows 10通知

在Java中, 如何生成不同类型的通知或警报非常令人困惑。一些开发人员更喜欢使用JOptionPane, 但是当你在固定环境中工作时(例如在Windows 10中), 使用Windows的默认通知样式非常好, 因此这就是为什么我们向你展示一个简短的摘要来显示Java AWT轻松实现Windows 10通知。以下代码…

matlab枚举类型,在 Simulink 模型中使用枚举数据

计算中的枚举值按照设计&#xff0c;Simulink 不允许在数学计算中将枚举值作为数值使用&#xff0c;即使枚举类是 MATLAB int32 类的子类也是如此。因此&#xff0c;尽管枚举类型存在基础整数&#xff0c;也不能作为数值类型使用。例如&#xff0c;您不能直接为 Gain 模块输入枚…

dataguard mysql,[dataguard同步数据库]Dataguard环境下数据库的备份与恢复

在线QQ客服&#xff1a;1922638专业的SQL Server、MySQL数据库同步软件在部署完active data guard后&#xff0c;不但可以将只读的查询交给备库执行&#xff0c;还可以把日常的数据库备份工作放在备库上执行&#xff0c;从而减轻主库的压力&#xff0c;充分的发挥服务器资源&am…

php getimagecompose,Docker进阶:Dockerfile以及docker-compose工具

Dockerfile&#xff1a;用来定制镜像的文件Docker-compose&#xff1a;用来部署容器集群的命令工具Dockerfile基本语法FROM&#xff1a;指定基础镜像&#xff0c;格式一般是FROM :FROM必须是Dockerfile的第一条非注释的命令是镜像名&#xff0c;是指定版本&#xff0c;不写的话…

Redis的安装以及使用

第一步&#xff0c;去官网下载一个压缩包到本地解压即用&#xff0c;绿色软件&#xff0c;不用其他操作&#xff0c;点击Download下载即可&#xff1a; Introduction to Redis | RedisLearn about the Redis open source projecthttps://redis.io/docs/about/第二步&#xff0…

oracle+行换列,Oracle的数据表中行转列与列转行的操作实例讲解

行转列一张表查询结果为--行转列select years,(select amount from Tb_Amount as A where month1 and A.yearsTb_Amount.years)as m1,(select amount from Tb_Amount as A where month2 and A.yearsTb_Amount.years)as m2,(select amount from Tb_Amount as A where month3 and…

js十秒没有点击怎么判断_MAC口红怎么判断真假?没批号就没有生产日期,网友:品控太差...

一般来说&#xff0c;MAC的口红产品&#xff0c;底部都会有三位编码&#xff0c;这是该款口红的批号。因像MAC这类国外美妆护肤品牌&#xff0c;是不会将生产日期明确的标注在产品上&#xff0c;都是将其编码成批号&#xff0c;在标注在外包装或者产品的侧面、底部等边缘位置。…

go run main.go 参数_介绍一款Go项目热编译工具gowatch

使用场景在golang项目编写过程中&#xff0c;需要对项目不断的进行构建go build并调试以快速发现问题&#xff0c;而我们每次进行手动的进行go build又太重复&#xff0c;所以写了这么一个工具gowatch来实时的监听文件的改动并编译运行&#xff0c;大大提升开发效率。快速入门安…

安卓rpg绅士游戏资源_海贼无双3(动作游戏)——电脑安卓单机游戏下载资源分享...

点击上方蓝字关注我们01游戏简介&#xff1a;游戏名称&#xff1a;海贼无双3其它名称&#xff1a;One Piece - Pirate Warriors 3游戏类型&#xff1a;动作游戏开发发行&#xff1a;Omega Force游戏平台&#xff1a;PC整理时间&#xff1a;2020-04-25官方网址&#xff1a;http:…

11210怎么等于24_想要消耗100大卡热量,怎么做才最简单?

减肥&#xff0c;最根本的原理就是制造热量差&#xff0c;从饮食上限制热量的摄入&#xff0c;调理体质让基础代谢更高&#xff0c;运动来进一步增加消耗&#xff0c;当热量差达到7000大卡左右的时候&#xff0c;就能瘦下来1kg的纯脂肪&#xff01;美食当前&#xff0c;自然要先…

连接linux工具Mtr,Linux常用网络工具:路由扫描之mtr

除了上一篇《Linux常用网络工具&#xff1a;路由扫描之traceroute》介绍的traceroute之外&#xff0c;一般Linux还内置了另一个常用的路由扫描工具mtr。mtr在某些方面比traceroute更好用&#xff0c;它可以实时显示经过的每一跳路由的信息&#xff0c;并不断进行探测。tracerou…

redis rua解决库存问题_【150期】面试官:Redis的各项功能解决了哪些问题?

点击上方“Java面试题精选”&#xff0c;关注公众号面试刷图&#xff0c;查缺补漏>>号外&#xff1a;往期面试题&#xff0c;10篇为一个单位归置到本公众号菜单栏->面试题&#xff0c;有需要的欢迎翻阅阶段汇总集合&#xff1a;一百期面试题汇总先看一下Redis是一个什…

启动盘Linux windows,Linux 中创建 USB 启动盘来拯救 Windows 用户

人们经常要求我帮助他们恢复被锁死或损坏的 Windows 电脑。有时&#xff0c;我可以使用 Linux USB 启动盘来挂载 Windows 分区&#xff0c;然后从损坏的系统中传输和备份文件。有的时候&#xff0c;客户丢失了他们的密码或以其他方式锁死了他们的登录账户凭证。解锁账户的一种方…

linux桌面版自动更新关闭了,桌面应用|开启 Ubuntu 系统自动升级

在学习如何开启Ubuntu系统自动升级之前&#xff0c;先解释下为什么需要自动升级。默认情况下&#xff0c;ubuntu每天一次检查更新。但是一周只会弹出一次软件升级提醒&#xff0c;除非当有安全性升级时&#xff0c;才会立即弹出。所以&#xff0c;如果你已经使用Ubuntu一段时间…

做自适应网站专业乐云seo_什么叫网站优化-网站建设-SEO优化

公司致力于企业品牌营销策划、网站建设、网站优化、五网竞价推广、商城建设、小程序开发、搜索引擎推广、SEO及企业品牌整合营销、全网整合营销霸屏推广等专业一站式网络全包服务。为不同企业品牌量身定制合适的设计方案&#xff0c;提供专业一站式网站服务平台、网络广告投放平…