【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;
}
相关推荐
一个天蝎座 白勺 程序猿41 分钟前
Python爬虫(8)Python数据存储实战:JSON文件读写与复杂结构化数据处理指南
爬虫·python·json
q_q王1 小时前
dify对接飞书云文档,并且将图片传入飞书文档
python·大模型·飞书·dify·智能体·图片展示
noravinsc1 小时前
django filter 排除字段
后端·python·django
zandy10112 小时前
嵌入式BI开发指南:如何通过衡石API将分析能力集成到业务系统?
开发语言·python·嵌入式
曲幽2 小时前
零基础快速搭建AI绘画网站!用Gradio玩转Stable Diffusion
python·ai作画·stable diffusion·gradio·diffusers·webui
2401_890665862 小时前
免费送源码:Java+ssm+HTML 三分糖——甜品店网站设计与实现 计算机毕业设计原创定制
java·python·微信小程序·html·php·课程设计·android-studio
敲代码的瓦龙2 小时前
C++?动态内存管理!!!
c语言·开发语言·数据结构·c++·后端
noravinsc2 小时前
django filter 日期大于当前日期的
python·django
悲喜自渡7212 小时前
pytorch & python常用指令
人工智能·pytorch·python
Star abuse3 小时前
Python爬虫课程实验指导书
开发语言·爬虫·python