题目描述

护卫车队在一条单行的街道前排成一队,前面河上是一座单行的桥。因为街道是一条单行道,所以任何车辆都不能超车。桥能承受一个给定的最大承载量。为了控制桥上的交通,桥两边各站一个指挥员。护卫车队被分成几个组,每组中的车辆都能同时通过该桥。当一组车队达到了桥的另一端,该端的指挥员就用电话通知另一端的指挥员,这样下一组车队才能开始通过该桥。每辆车的重量是已知的。任何一组车队的重量之和不能超过桥的最大承重量。被分在同一组的每一辆车都以其最快的速度通过该桥。一组车队通过该桥的时间是用该车队中速度最慢的车通过该桥所需的时间来表示的。问题要求计算出全部护卫车队通过该桥所需的最短时间值。

输入输出格式

输入格式:

输入文件第一行包含三个正整数(用空格隔开),第一个整数表示该桥所能承受的最大载重量(用吨表示);第二个整数表示该桥长度(用千米表示);第三个整数表示该护卫队中车辆的总数(n<1000)。接下来的几行中,每行包含两个正整数W和S(用空格隔开),W表示该车的重量(用吨表示),S表示该车过桥能达到的最快速度(用千米/小时表示)。车子的重量和速度是按车子排队等候时的顺序给出的。

输出格式:

输出文件应该是一个实数,四舍五入精确到小数点后1位,表示整个护卫车队通过该桥所需的最短时间(用分钟表示)。

输入输出样例

输入样例#1: 复制

100 5 10
40 25
50 20
50 20
70 10
12 50
9 70
49 30
38 25
27 50
19 70
输出样例#1: 复制

75.0
//用sw[i]表示前i辆车的总重量
//minv[i][j]表示第i~j辆车中的速度最小的车的速度
//dp[i]表示前i辆车过桥所用的最短时间
//初始化dp[i]=dp[i-1]+L/v[i]
//dp[j]=min(dp[j],dp[i-1]+1.0*L/minv[i][j]); #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; const int N=1e3+; long long W,L,S;
long long w[N],v[N];
long long sw[N],minv[N][N];
double dp[N]; inline long long read()
{
char c=getchar();long long num=;
for(;!isdigit(c);c=getchar());
for(;isdigit(c);c=getchar())
num=num*+c-'';
return num;
} int main()
{
W=read(),L=read(),S=read();
for(int i=;i<=S;++i)
{
w[i]=read(),v[i]=read();
sw[i]=sw[i-]+w[i];
minv[i][i]=v[i];
dp[i]=;
}
for(int i=;i<=S;++i)
{
for(int j=i+;j<=S;++j)
minv[i][j]=min(minv[i][j-],v[j]);
}
dp[]=;
for(int i=;i<=S;++i)
{
for(int j=i;j<=S;++j)
{
if(sw[j]-sw[i-]<=W)
{
dp[j]=min(dp[j],dp[i-]+1.0*L/minv[i][j]);
}
else
break;
}
}
// for(int i=1;i<=S;++i)
// {
// dp[i]=dp[i-1]+1.0*L/v[i];
// for(int j=i-1;j;--j)
// {
// if(sw[i]-sw[j-1]<=W)
// {
// dp[i]=min(dp[i],dp[j-1]+1.0*L/minv[j][i]);
// }
// else
// break;
// }
// }
printf("%.1lf",dp[S]*);
return ;
}

最新文章

  1. vs 2005 thread 无法调试
  2. PHP获取用户真实IP
  3. 【转】Eclipse 常用快捷键 (动画讲解)
  4. javascript中的对象之间继承关系
  5. VC程序查错之内存访问异常
  6. Java位运算总结:位运算用途广泛《转》
  7. 深入了解VSTS的Unit Test测试属性
  8. 0x80072f8a未指定的错误
  9. LeetCode OJ 98. Validate Binary Search Tree
  10. laravel提示Mcrypt PHP extension required
  11. debian将默认中文改成英文
  12. html基本标签与属性
  13. linux基本
  14. tensorflow笔记9:nn_ops.bias_add 函数
  15. ssh免密登陆
  16. Pandas之数据结构
  17. C# iTextSharp 生成 PDF
  18. [Objective-C语言教程]内存管理(36)
  19. 19-3-8Python中编码的进阶、文件操作初识、深浅copy
  20. javascript 分号理解

热门文章

  1. chrome 调试 ios h5
  2. scratch少儿编程第一季——05、移动还可以这样动
  3. SAS学习笔记16 SAS创建计数(枚举)变量
  4. (二)如何利用C# Roslyn编译器写一个简单的代码提示/错误检查?
  5. 表空间 oracle
  6. cli create ssl certkey
  7. 安装Nvida 显示环境
  8. js入门之数组
  9. MVC框架+vue+elementUI
  10. 运行 jar 的问题