【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 游乐园门票 (200分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员

✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解

💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导

👏 感谢大家的订阅➕ 和 喜欢💗

最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测

最新华为OD机试目录: https://blog.csdn.net/Qmtdearu/article/details/139390785

📎在线评测链接

https://app5938.acapp.acwing.com.cn/contest/2/problem/OD1077

🌍 评测功能需要 ⇒ 订阅专栏 ⇐ 后私信联系清隆解锁~

🍓OJ题目截图

文章目录

🎀 游乐园门票

问题描述

A先生是一家著名游乐园"Wonderland"的经理,该游乐园提供4种不同的门票:一日票、三日票、周票和月票。每种门票的价格不同,持有门票的游客可以在有效期内无限次游玩。

具体而言:

  • 一日票: 仅限当日有效
  • 三日票: 从购买当日起,连续3天内有效
  • 周票: 从购买当日起,连续7天内有效
  • 月票: 从购买当日起,连续30天内有效

现在给定每种门票的价格,以及LYA计划在未来一年内的游玩日期,请帮助LYA计算出她需要支付的最低门票费用。

输入格式

第一行包含4个整数,分别表示一日票、三日票、周票和月票的价格。

第二行包含若干个整数,用空格分隔,表示LYA计划游玩的日期。日期按升序给出,范围在1到365之间。

输出格式

一个整数,表示LYA需要支付的最低门票费用。

样例输入

5 14 30 100
1 3 5 20 21 200 202 230

样例输出

40

样例解释

根据给定的门票价格和游玩日期,LYA最便宜的方式是每次购买一张一日票,共需支付8 * 5 = 40元。

数据范围

  • 门票价格在1到10000之间
  • 游玩日期数量在1到365之间

题解

我们可以使用动态规划来解决这个问题。定义 f[i] 为在第 i 天时,LYA需要支付的最低门票费用。初始时 f = 0

对于每一天 i,我们有两种情况:

  1. 如果LYA在第 i 天不需要游玩,那么 f[i] = f[i-1]
  2. 如果LYA在第 i 天需要游玩,那么我们需要考虑购买哪种门票最便宜。对于每种门票,我们计算从上次购买该门票到现在的最低费用,取最小值作为 f[i]

最终的答案就是 f[365]

参考代码

  • Python
python 复制代码
import sys

def mincostTickets(days, costs):
    dp = [sys.maxsize] * (days[-1] + 1)
    days_set = set(days)
    dp[0] = 0
    
    for i in range(1, days[-1] + 1):
        if i not in days_set:
            dp[i] = dp[i - 1]
        else:
            dp[i] = min(dp[i - 1] + costs[0], dp[max(0, i - 3)] + costs[1], dp[max(0, i - 7)] + costs[2], dp[max(0, i - 30)] + costs[3])
    
    return dp[-1]

costs = list(map(int, input().split()))
days = list(map(int, input().split()))
print(mincostTickets(days, costs))
  • Java
java 复制代码
import java.util.*;

public class Main {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int[] durations = {1, 3, 7, 30};
        int[] costs = new int[4];
        for (int i = 0; i < 4; i++) {
            costs[i] = in.nextInt();
        }

        in.nextLine();
        String[] s = in.nextLine().split(" ");
        int n = s.length;
        int[] days = new int[n];
        for (int i = 0; i < n; i++) {
            days[i] = Integer.parseInt(s[i]);
        }

        boolean[] isPlayDay = new boolean[366];
        for (int day : days) {
            isPlayDay[day] = true;
        }

        int[] dp = new int[366];
        Arrays.fill(dp, Integer.MAX_VALUE);
        dp[0] = 0;

        for (int i = 1; i < 366; i++) {
            if (isPlayDay[i]) {
                for (int j = 0; j < 4; j++) {
                    dp[i] = Math.min(dp[i], dp[Math.max(0, i - durations[j])] + costs[j]);
                }
            } else {
                dp[i] = dp[i - 1];
            }
        }

        System.out.println(dp[365]);
    }
}
  • Cpp
cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
#include <climits>

using namespace std;

int mincostTickets(vector<int>& days, vector<int>& costs) {
    vector<int> dp(366, INT_MAX);
    vector<bool> isPlayDay(366, false);

    for (int day : days) {
        isPlayDay[day] = true;
    }

    dp[0] = 0;

    for (int i = 1; i < 366; ++i) {
        if (!isPlayDay[i]) {
            dp[i] = dp[i - 1];
        } else {
            dp[i] = min({dp[i - 1] + costs[0], 
                         dp[max(0, i - 3)] + costs[1], 
                         dp[max(0, i - 7)] + costs[2], 
                         dp[max(0, i - 30)] + costs[3]});
        }
    }

    return dp[365];
}

int main() {
    vector<int> costs(4);
    for (int i = 0; i < 4; ++i) {
        cin >> costs[i];
    }

    vector<int> days;
    int day;
    while (cin >> day) {
        days.push_back(day);
    }

    cout << mincostTickets(days, costs) << endl;

    return 0;
}
相关推荐
嵌入式科普4 分钟前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
qq_5290252933 分钟前
Torch.gather
python·深度学习·机器学习
数据小爬虫@33 分钟前
如何高效利用Python爬虫按关键字搜索苏宁商品
开发语言·爬虫·python
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
終不似少年遊*1 小时前
pyecharts
python·信息可视化·数据分析·学习笔记·pyecharts·使用技巧
Python之栈1 小时前
【无标题】
数据库·python·mysql
袁袁袁袁满1 小时前
100天精通Python(爬虫篇)——第113天:‌爬虫基础模块之urllib详细教程大全
开发语言·爬虫·python·网络爬虫·爬虫实战·urllib·urllib模块教程
小林熬夜学编程2 小时前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
老大白菜2 小时前
Python 爬虫技术指南
python
Jackey_Song_Odd2 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表