hdu-2059(dp)

hdu-2059 龟兔赛跑

在这里插入图片描述

dp[i] 表示到第i个站所花费的最少时间,t[j][k]表示在第j个站充满电,直接开到第k个站所花的时间,那么状态转移为: dp[i] = min(dp[i], dp[j] + t[j][i])
含义为,假设我们当前想知道到达第i个站的最少时间,那么到前面i-1个站的最少时间都已经知道了,计算时间相加即可。
不需要考虑x位于i,j之间的站需不需要充电,假设x位于i,j之间:
情况1:x不充电,直接计算之间,更新dp[i]
情况2:x充电,但是,x站点在j站点之后,这种情况是包含在之前的状态里的

#include<bits/stdc++.h>using namespace std;
const int maxn = 1e5 + 5;
const double pi = 3.1415927;
const int mod = 1000;
typedef long long ll;// dp[i] 表示到第i个站最少时间
double dp[105];
int a[105];void solve() {int l;while (cin>>l){memset(dp, 1000000000.0, size(dp));int n,c,t;cin>>n>>c>>t;int vr, vt1,vt2;cin>>vr>>vt1>>vt2;for(int i=1;i<=n;i++) cin>>a[i];a[n+1] = l;for(int i=1;i<=n+1;i++){for(int j=0;j<i;j++){int dis = a[i] - a[j];double temp = 0.0;if (dis <= c){temp += 1.0*dis/vt1;}else temp = 1.0*c/vt1 + 1.0*(dis - c)/ vt2;if (j != 0) temp += 1.0*t;dp[i] = min(dp[i], dp[j]+temp);}}double tr = 1.0*l/vr;if (dp[n+1] >= tr) cout<<"Good job,rabbit!\n";else cout<<"What a pity rabbit!\n";}
}int main() {int T = 1;
//    cin >> T;
//    init();while (T--) {solve();}return 0;
}

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

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

相关文章

Java定时调度范式定时操作

在 Java 中&#xff0c;我们可以使用各种方法来执行定时操作。这些操作包括执行任务、调度任务、执行重复任务等。下面将介绍几种常见的 Java 定时调度范式。 1. Timer 和 TimerTask Java 提供了 Timer 和 TimerTask 类&#xff0c;用于执行定时任务。 示例代码&#xff1a;…

RK3568平台 USB数据包的收发格式

一.USB硬件拓扑结构 compound device &#xff1a;多个设备组合起来&#xff0c;通过HUB跟Host相连composite device &#xff1a;一个物理设备有多个逻辑设备(multiple interfaces) 在软件开发过程中&#xff0c;我们可以忽略Hub的存在&#xff0c;硬件拓扑图简化如下&#x…

【精品】集合list去重

示例一&#xff1a;对于简单类型&#xff0c;比如String public static void main(String[] args) {List<String> list new ArrayList< >();list.add("aaa");list.add("bbb");list.add("bbb");list.add("ccc");list.add(…

【蓝桥杯基础算法】dfs(上)组合数,全排列

刚接触算法&#xff0c;有没有被递归又循环的dfs吓到&#xff1f;没关系&#xff0c;几个例题就可以彻底掌握&#xff01; 1.全排列 1-n的全排列,如输入3&#xff0c;按顺序对1-3进行排列 //枚举 #include<iostream> #include<algorithm> #include<cstring>…

Unity UGUI之Slider基本了解

在Unity中&#xff0c;Slider&#xff08;滑动条&#xff09;是一种常用的用户界面控件之一&#xff0c;允许用户通过拖动滑块来选择一个数值。常常应用于调节数值&#xff08;如调节音量、亮度、游戏难度等&#xff09;、设置选项等。 以下是Slider的基本信息和用法: 1、创建…

WPS/Office 好用的Word插件-查找替换

例如&#xff1a;一片文档&#xff1a;…………泰山…………泰&#xff08;少打了山字&#xff09;………… 要是把“泰”查找替换为“泰山”&#xff0c;就会把前面的“泰山”变成“泰山山”&#xff0c;这种问题除了再把“泰山山”查找替换为“泰山”&#xff0c;有没有更简单…

SAR ADC学习笔记(4)

CDAC电容阵列 一、电容失配 二、电容失配对CDAC线性度的影响 1.电容失配对DNL的影响 2.电容失配对INL的影响 三、分段结构的CDAC 四、CDAC开关切换方案&#xff1a;传统开关切换策略 第一次比较阶段&#xff1a;如果VP(1)-VN(1)<0 第一次比较阶段&#xff1a;如果VP(1)-VN…

opengl 学习(三)-----着色器

着色器 分类demo效果解析教程 分类 OPengl C demo #include "glad/glad.h" #include "glfw3.h" #include <iostream> #include <cmath> #include <vector>#include <string> #include <fstream> #include <sstream>…

主语补足语SC【语法笔记】

1.主语补足语的作用是什么 2.主语补足语与宾语补足语的区别与联系是什么 3.see do 与 doing &#xff0c;在进行主补与宾补互换时候&#xff0c;不同点是什么 4.主语补足语由什么构成 5.例题

Mybatis-Plus Mapper映射文件使用

介绍 MyBatis 的真正强大在于它的语句映射&#xff0c;这是它的魔力所在。由于它的异常强大&#xff0c;映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比&#xff0c;你会立即发现省掉了将近 95% 的代码。MyBatis 致力于减少使用成本&#xff0…

T01类加载机制

类加载机制 类加载运行全过程 当我们用java命令运行某个类的main函数启动程序时&#xff0c;首先需要通过类加载器把主类加载到JVM public class Math {public static final int initData 666;public static User user new User();public int compute() {int a 1;int b …

[LeetCode][239]【学习日记】滑动窗口最大值——O(n)单调队列

题目 239. 滑动窗口最大值 难度&#xff1a;困难相关标签相关企业提示 给你一个整数数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回滑动窗口中的最大值。 示例 1…