游艇出租问题(动态规划)

2023-12-13 08:50

本文主要是介绍游艇出租问题(动态规划),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

长江游艇俱乐部在长江上设置了n个游艇出租站1,2,3…,n。游客可以在这些游艇出租站用游艇,并在下游的任何一个游艇出租站归还游艇。游艇出租站i到游艇出租站j之间的租金为r(i,j),1<=i<j=n。试设计一个算法,计算从游艇出租站1到出租站n所需的最少租金。

输入描述:第一行表示有n个站点,接下来n-1行是r( i ,  j)。

输出描述:输出从游艇出租站1到出租站3所需的最少租金

样例输入:

3            //站数

5 15     //从第1站到其他相应各站的租金

7           //从第2站到其他相应各站的租金

样例输出:

12

 算法设计:
使用动态规划的思想,通过逐步计算每个出租站的最小租金,并利用已知的最小租金来计算后续出租站的最小租金。设dp[n]为出租站1到达出租站n-1所需最小租金,rent[i][j]为出租站i到出租站j的租金。先考虑边界条件:dp[0]=0,即从出租站1到达自身的租金为0;易知,当前出租站i所需最小租金应该等于前i个出租站中第x个出租站的dp[x]值+rent[x][i](此时耗费的租金最少),所以遍历搜索前i个出租站dp值,得出最小耗费出租站x,即可得出dp[i],dp[n]则为从游艇出租站1到出租站n所需的最少租金。状态转移方程如下:


dp[i]=dp[x]+rent[x][i]

 代码实现:

#include <iostream>
using namespace std;
const int N=100;
int rent[N][N];
int MinRent(int n){int dp[n];// dp[n]表示从出租站1到达出租站n-1所需最小租金for (int i = 0; i < n; ++i) {   //用于存储最小租金,先定义为极大值dp[i]=INT_MAX;}dp[0]=0;// 从出租站1到达自身的租金为0for (int i = 1; i < n; ++i) {          //遍历所有出租站,得出dp[i]for (int x = 0; x < i; ++x) {if(dp[x]!=INT_MAX&&dp[x]+rent[x][i]<dp[i])dp[i]=dp[x]+rent[x][i];                    //动态转移方程}}return dp[n-1];
}
int main(){int n;cout << "请输入游艇出租站数n: ";cin >> n;cout << "请输入每站到达其他各站的租金\n";for (int i = 0; i < n - 1; i++) {for (int j = i + 1; j < n; j++) {cin >> rent[i][j];}}int min= MinRent(n);cout << "从第一站到第" << n << "站所需花费最小租金为: " << min << endl;
}

运行结果:

这篇关于游艇出租问题(动态规划)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/487843

相关文章

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

Spring MVC跨域问题及解决

《SpringMVC跨域问题及解决》:本文主要介绍SpringMVC跨域问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录跨域问题不同的域同源策略解决方法1.CORS2.jsONP3.局部解决方案4.全局解决方法总结跨域问题不同的域协议、域名、端口

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer