贮油点问题…..一道送命系列的递推…

描述 Description

一辆重型卡车欲穿过S公里的沙漠,卡车耗汽油为1升/公里,卡车总载油能力为W公升。显然卡车装一次油是过不了沙漠的。因此司机必须设法在沿途建立若干个贮油点,使卡车能顺利穿过沙漠。试问司机如怎样建立这些贮油点?每一贮油点应存储多少汽油,才能使卡车以消耗最少汽油的代价通过沙漠?

输入格式 Input Format

仅一行,读入整数S,W(S<=1000,W<=500)。

输出格式 Output Format

编程计算及打印建立的贮油点序号,各贮油点距沙漠边沿出发的距离以及存油量(输出到小数点后第二位)。格式

如下:

?       0     0.00  (dist)          ××(oil)

?       1     × ×  (dist)          ××(oil)

?       2     × ×            ××

?       …    ……            ……

注意:输出除了编号外距离和存油量均占10位。Pascal语言中表达为: Oir:10:2  Dist:10:2。

样例输入 Sample Input

1000 500

样例输出 Sample Output

0      0.00   3881.36

1     22.43   3500.00

2     60.89   3000.00

3    106.35   2500.00

4    161.90   2000.00

5    233.33   1500.00

6    333.33   1000.00

7    500.00    500.00

我最开始连题都读不懂…..怎么可能会写……直到有一天一个dalao告诉我说我校oj有题解,于是就去读了题解写完的…..感谢那个撰写题解的dalao….

首先声明一下这个题的题意…..(看了dalao题解思路才懂):

车子想要穿过沙漠,但是储油点是自己建立的

比如样例1

0    0.00   3881.36

就是说,自己在起点建立一个有 3881.36L的油点

然后跑向  22.43  这个储油点,一共跑了17次,一共卸下了3500L的油,消耗了381.36L的油

然后把剩下的3500L的油继续运向下一个储油点……

也就是说,车子是边走边建立储油点的,车子离开的时候,每个储油点的油都被运到了下一个储油点,到最后车子离开沙漠,油全部用完,储油点空空如也。

然后就是题解了:

如果从起点出发顺推,则我们无法确定第一个贮油点的位置及贮油量,因此我们可以用倒推法来解决这个问题:先从终点出发倒推最后一个储油点的位置及储油量,然后再把最后一个储油点作为终点,倒推倒数第二个储油点的位置及储油量。

因为题目中要求找最少的耗油,也就是说,最后一个储油点的位置离终点的距离就是汽车一次能行驶的距离,这样就可以直接装满油走了。那么我们就可以确定了最后一个储油点的位置,就是总路程s减去汽车油箱大小w,存储的油就是w。

然后根据最后一个储油点向前推,因为要在当前储油点运送w的油,而中途汽车运油的时候,还会消耗油量,那么就需要w*2的油,而储油点距离当前储油点的距离就是汽车消耗w油所走的路程除以来回的次数。

注意,最后一个点也就是最开始的点需要特判,手动赋值。

PS:发现从后往前每次运油的来回次数都是从1开始每次+2,(因为每次多运了w油,所以多走一个来回)。

那么我们用ai[p]表示最后一个点的距离,bi[p]表示最后一个点的油量,x表示来回数

则有:  ai[p-1]=ai[p]+w;

bi[p-1]=ai[p]-w/x;

这样我们就可以用循环来AC这道题了

代码如下:

 #include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <ctime>
using namespace std;
long long p=,l,x=,q=,t=;
double s,w,zb[],yl[],d=,cb[],cy[];//zb是逆推时存距离的,cb用来存储距离,方便后面倒着输出,yl存储逆推时的储油量,cy记录yl,同样为了方便倒着输出
int main(){
cin>>s>>w;
zb[]=s-w;
yl[]=w;
d=w;//d是储油点的距离
while(d!=) {//逆推得不到0,所以只要!=0就推就好了//自然是可以直接大于0的...这样下面那行<0的特判就不必要了...dalao可以尝试下,反正我失败了、。。。
q++;//q是循环的次数
x+=;
l=p;
yl[p+]=yl[p]+w;
zb[p+]=zb[p]-w/x;
d=zb[p];
if(d<){//但是会出现小于0的情况,这是我们直接结束循环即可
p--;
break;
}
cb[p]=zb[p];
cy[p]=yl[p];
p++;
}
cb[p+]=0.00;//最后一组距离为0.00的情况需要特判
cy[p+]=yl[p]+zb[p]*x;
for(int i=q;i>=;i--){
cout<<setiosflags(ios::fixed)<<setprecision();
cout<<t<<' '<<cb[i]<<' '<<cy[i]<<endl;
t++;//t表示储油点的序号,从0开始
}
return ;
}

PS:网上的贮油点问题大多没有完整的通俗易懂的代码……发出来造福群众……

PS:看代码AC就看代码AC了吧……反正对于敲程序的人没有任何益处,对我也没有任何坏处……

贮油点问题(C++)的更多相关文章

  1. 【a302】&&【9306】贮油点问题

    Time Limit: 1 second Memory Limit: 2 MB 问题描述 一辆重型卡车欲穿过1000公里的沙漠,卡车耗油为1升/公里,卡车总载油能力为500公升.显然卡车装 一次油是过 ...

  2. c语言-递推算法1

    递推算法之一:倒推法 1.一般分析思路: if 求解初始条件F1 then begin { 倒推 } 由题意(或递推关系)确定最终结果Fn; 求出倒推关系式Fi-1 =G(Fi ); i=n; { 从 ...

  3. 从零开始学 Java - Spring 集成 ActiveMQ 配置(一)

    你家小区下面有没有快递柜 近两年来,我们收取快递的方式好像变了,变得我们其实并不需要见到快递小哥也能拿到自己的快递了.对,我说的就是类似快递柜.菜鸟驿站这类的代收点的出现,把我们原来快递小哥必须拿着快 ...

  4. utf-8 汉字对照表

    之前从redis中取出一些数据,utf8 16进制编码,想转成字符,没有找到现成的转化工具,先用这个表直接查找对照吧. UTF8编码表大全Code code# Code (coded in UTF-8 ...

  5. ActiveMQ

    前言 MQ--Message Queue,中文翻译为"消息队列",维基百科上的这样描述: 消息队列(英语:Message queue)是一种进程间通信或同一进程的不同线程间的通信方 ...

  6. Windows操作系统

    Microsoft Windows,是美国微软公司研发的一套操作系统,它问世于1985年,起初仅仅是Microsoft-DOS模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家 ...

  7. php 中文繁简体转换

    <?php $testC = new TestC (); $testC->index (); class TestC { private $utf8_gb2312; private $ut ...

  8. js 简繁体字转换

    有些项目需要用到简体和繁体两种字体,在js前台进行转换比较方便而且显示速度没有延时 是一个比较好的解决方案. var _isFT_CS = 0// 简体 var _isFT_CT = 1// 繁体 v ...

  9. Sort merge join、Nested loops、Hash join(三种连接类型)

    目前为止,典型的连接类型有3种: Sort merge join(SMJ排序-合并连接):首先生产driving table需要的数据,然后对这些数据按照连接操作关联列进行排序:然后生产probed ...

随机推荐

  1. P4109 [HEOI2015]定价

    题目描述 在市场上有很多商品的定价类似于 999 元.4999 元.8999 元这样.它们和 1000 元.5000 元和 9000 元并没有什么本质区别,但是在心理学上会让人感觉便宜很多,因此也是商 ...

  2. Codeforces 662C(快速沃尔什变换 FWT)

    感觉快速沃尔什变换和快速傅里叶变换有很大的区别啊orz 不是很明白为什么位运算也可以叫做卷积(或许不应该叫卷积吧) 我是看 http://blog.csdn.net/liangzhaoyang1/ar ...

  3. [洛谷P1251]餐巾计划问题

    题目大意:一个餐厅N天,每天需要$r_i$块餐巾.每块餐巾需要p元,每天用过的餐巾变脏,不能直接用.现在有快洗店和慢洗店,快洗店洗餐巾需要m天,每块花费f元:慢洗店洗餐巾需要n天,每块餐巾s元(m & ...

  4. GDI+小例子

    原文链接地址:http://www.cnblogs.com/chuanzifan/archive/2011/11/26/2264507.html 1.在stdafx.h中 #include <G ...

  5. Dubbo入门介绍---搭建一个最简单的Demo框架

    Dubbo入门---搭建一个最简单的Demo框架 置顶 2017年04月17日 19:10:44 是Guava不是瓜娃 阅读数:320947 标签: dubbozookeeper 更多 个人分类: D ...

  6. linux内存条排查

    已发现2个内存错误,应用名称(kernel:),日志内容(hangzhou-jishuan-DDS0248 kernel: sbridge: HANDLING MCE MEMORY ERROR han ...

  7. 仿FLASH的图片轮换效果

    css布局代码(test.css): body { background: #ccc;} ul { padding: 0; margin: 0;} li { list-style: none;} im ...

  8. 前端面试:js闭包,为什么要使用闭包

    要理解闭包,首先理解javascript特殊的变量作用域,变量的作用于无非就是两种:全局变量,局部变量. javascript语言的特殊处就是函数内部可以读取全局变量. 1.如何从外部读取局部变量? ...

  9. Exceptioninthread"main"java.lang.ClassNotFoundsException的问题

    报错如下: Exceptioninthread"main"java.lang.ClassNotFoundsException 大致可以判断出是无法定位到main方法,应该是用mav ...

  10. 51nod 1040 最大公约数之和

    给出一个n,求1-n这n个数,同n的最大公约数的和.比如:n = 6 1,2,3,4,5,6 同6的最大公约数分别为1,2,3,2,1,6,加在一起 = 15   Input 1个数N(N <= ...