当前位置: 首页 > news >正文

LeetCode983. Minimum Cost For Tickets——动态规划

文章目录

    • 一、题目
    • 二、题解

一、题目

You have planned some train traveling one year in advance. The days of the year in which you will travel are given as an integer array days. Each day is an integer from 1 to 365.

Train tickets are sold in three different ways:

a 1-day pass is sold for costs[0] dollars,
a 7-day pass is sold for costs[1] dollars, and
a 30-day pass is sold for costs[2] dollars.
The passes allow that many days of consecutive travel.

For example, if we get a 7-day pass on day 2, then we can travel for 7 days: 2, 3, 4, 5, 6, 7, and 8.
Return the minimum number of dollars you need to travel every day in the given list of days.

Example 1:

Input: days = [1,4,6,7,8,20], costs = [2,7,15]
Output: 11
Explanation: For example, here is one way to buy passes that lets you travel your travel plan:
On day 1, you bought a 1-day pass for costs[0] = $2, which covered day 1.
On day 3, you bought a 7-day pass for costs[1] = $7, which covered days 3, 4, …, 9.
On day 20, you bought a 1-day pass for costs[0] = $2, which covered day 20.
In total, you spent $11 and covered all the days of your travel.
Example 2:

Input: days = [1,2,3,4,5,6,7,8,9,10,30,31], costs = [2,7,15]
Output: 17
Explanation: For example, here is one way to buy passes that lets you travel your travel plan:
On day 1, you bought a 30-day pass for costs[2] = $15 which covered days 1, 2, …, 30.
On day 31, you bought a 1-day pass for costs[0] = $2 which covered day 31.
In total, you spent $17 and covered all the days of your travel.

Constraints:

1 <= days.length <= 365
1 <= days[i] <= 365
days is in strictly increasing order.
costs.length == 3
1 <= costs[i] <= 1000

二、题解

class Solution {
public:int mincostTickets(vector<int>& days, vector<int>& costs) {vector<int> durations = {1,7,30};int n = days.size();vector<int> dp(n+1,INT_MAX);dp[n] = 0;for(int i = n - 1;i >= 0;i--){for(int k = 0,j = i;k < 3;k++){while(j < n && days[i] + durations[k] > days[j]) j++;dp[i] = min(dp[i],costs[k] + dp[j]);}}return dp[0];}
};
http://www.lryc.cn/news/296375.html

相关文章:

  • 百卓Smart管理平台 uploadfile.php 文件上传漏洞【CVE-2024-0939】
  • 项目中常用的一些数据库及缓存
  • MoE-LLaVA:具有高效缩放和多模态专业知识的大型视觉语言模型
  • 【Java】ArrayList和LinkedList的区别是什么
  • RabbitMQ-4.MQ的可靠性
  • 编程相关的经典的网站和书籍
  • Java代码实现基数排序算法(附带源码)
  • 基于python+django,我开发了一款药店信息管理系统
  • VSCODE使用ssh远程连接时启动服务器失败问题
  • easyexcle 导出csv
  • Ubuntu22.04 gnome-builder gnome C 应用程序习练笔记(一)
  • ESP32QRCodeReader库使用,ESP32-CAM识别二维码并向自写接口发出请求确认身份。
  • 什么是网络渗透,应当如何防护?
  • 掌握C++中的动态数据:深入解析list的力量与灵活性
  • 天地伟业接入视频汇聚/云存储平台EasyCVR详细步骤
  • Vue源码系列讲解——虚拟DOM篇【二】(Vue中的DOM-Diff)
  • 基于AST实现一键自动提取替换国际化文案
  • 嵌入式硬件工程师与嵌入式软件工程师
  • 【华为云】云上两地三中心实践实操
  • Linux大集合
  • 深入解析 Spring 事务机制
  • 第9章 安全漏洞、威胁和对策(9.11-9.16)
  • Mysql-数据库压力测试
  • CI/CD总结
  • 【CSS】margin塌陷和margin合并及其解决方案
  • Python并发
  • 2024-02-04(hive)
  • P9420 [蓝桥杯 2023 国 B] 子 2023 / 双子数--2024冲刺蓝桥杯省一
  • The Back-And-Forth Method (BFM) for Wasserstein Gradient Flows windows安装
  • 【GAMES101】Lecture 19 透镜