华为OD机试 - 代表团坐车 - 动态规划(Java 2023 B卷 200分)

news/2024/6/16 0:15:24 标签: 华为od, 动态规划, java, 七日集训, 学习, 送书

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示
      • 1、输入
      • 2、输出
      • 3、说明

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

一、题目描述

某组织举行会议,来了多个代表团同时到达,接待处只有一辆汽车,可以同时接待多个代表团,为了提高车辆利用率,请帮接待员计算可以坐满的接待方案,输出方案数量。

约束:

  1. 一个团只能上一辆车,并且代表团(代表团数量小于30,每个代表团人数小于30)小于汽车容量(汽车容量小于100);
  2. 需要将车辆坐满。

二、输入描述

第一行输入代表团人数,英文逗号隔开,代表团数量小于30,每个代表团人数小于30
第二行输入汽车载客量,汽车容量小于100

三、输出描述

坐满汽车的方案数量
如果无解输出0

四、解题思路

  1. 第一行输入代表团人数,英文逗号隔开;
  2. 第二行输入汽车载客量,汽车容量小于100;
  3. 通过java8 Stream表达式(简洁/方便/上档次)快速拆解输入行;
  4. 初始化动态规划数组,dp[i]表示载客量为i时的方案数;
  5. 载客量为0时,方案数为1(不接待任何代表团);
  6. 动态规划转移,从后往前遍历,避免重复计算;
  7. 转移方程:dp[j] += dp[j - group],表示加上接待当前代表团后的方案数;
  8. 输出坐满汽车的方案数量;

五、Java算法源码

java">package com.guor.od;

import java.util.*;

public class OdTest {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        // 读取代表团人数
        int[] groups = Arrays.stream(sc.nextLine().split(",")).mapToInt(Integer::parseInt).toArray();

        // 读取汽车载客量
        int capacity = Integer.parseInt(sc.nextLine());

        // 初始化动态规划数组,dp[i]表示载客量为i时的方案数
        int[] dp = new int[capacity + 1];
        // 载客量为0时,方案数为1(不接待任何代表团)
        dp[0] = 1;

        // 动态规划转移
        for (int group : groups) {
            // 从后往前遍历,避免重复计算
            for (int j = capacity; j >= group; j--) {
                // 转移方程:dp[j] += dp[j - group],表示加上接待当前代表团后的方案数
                dp[j] += dp[j - group];
            }
        }

        // 无解
        if (dp[capacity] == 0) {
            System.out.println(0);
        } else { // 有解
            System.out.println(dp[capacity]);
        }
    }
}

六、效果展示

1、输入

5,4,2,3,2,4,9
10

2、输出

4

3、说明

解释以下几种方式都可以坐满扯,所以优先街道输出为4
[2, 3, 5]
[2, 4, 4]
[2, 3, 5]
[2, 4, 4]

在这里插入图片描述


🏆下一篇:华为OD机试真题 Java 实现【路灯照明问题】【2022Q4 100分】,感谢fly晨发现这个问题,并提供更优质的算法

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述


http://www.niftyadmin.cn/n/5111901.html

相关文章

【UnityUGUI】UGUI六大组件和三大基本控件详解

👨‍💻个人主页:元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏:UI_…

数据结构学习系列之双向链表的翻转

双向链表的翻转:与单向链表翻转的思路一致,都是 将第0个数据结点后面的所有数据结点,依次头插到头结点和第0个数据结点之间即可,代码如下:示例代码: //翻转 int filp_dplink_list(node_t *phead){if(NULL …

Vue18 v-for指令 展示列表数据

v-for指令: 1.用于展示列表数据2.语法&#xff1a;v-for"(item, index) in xxx" :key"yyy"3.可遍历&#xff1a;数组、对象、字符串&#xff08;用的很少&#xff09;、指定次数&#xff08;用的很少&#xff09;<!DOCTYPE html> <html><he…

Hadoop3教程(二十八):(生产调优篇)NN、DN的多目录配置及磁盘间数据均衡

文章目录 &#xff08;148&#xff09;NN多目录配置&#xff08;149&#xff09;DataNode多目录配置及磁盘间数据平衡磁盘间数据均衡 参考文献 &#xff08;148&#xff09;NN多目录配置 NN多目录的意思是&#xff0c;本地目录可以配置成多个&#xff0c;且每个目录存放内容相…

【大数据 - Doris 实践】数据表的基本使用(四):动态分区

数据表的基本使用&#xff08;四&#xff09;&#xff1a;动态分区 1.原理2.使用方式3.动态分区规则参数3.1 主要参数3.2 创建历史分区的参数3.3 创建历史分区规则3.4 创建历史分区举例3.5 注意事项 4.示例4.1 创建动态分区表4.2 查看动态分区表调度情况4.3 查看表的分区4.4 插…

颜色直方图图像检索

颜色直方图图像检索是一种基于图像颜色分布的图像检索方法。它的基本思想是通过计算图像的颜色直方图&#xff0c;然后使用这些直方图来比较和匹配图像。这种方法通常用于在大规模图像数据库中查找相似图像&#xff0c;或者用于图像检索和分类任务。 以下是一些颜色直方图图像检…

【斗破年番】彩鳞送老公新挂,薰儿霸气回归,萧炎招揽古河,邀请美杜莎战魂殿

【侵权联系删除】【文/郑尔巴金】 斗破苍穹年番动画已经更新了&#xff0c;萧炎与美杜莎女王一起回娘家&#xff0c;并且也与小医仙制定了同盟计划&#xff0c;准备对金雁宗与慕兰谷斩草除根。从官方公布的第69集预告来看&#xff0c;慕兰三老与雁落天已经陨落&#xff0c;美杜…

利用jupyter进行分类

Jupyter Notebook是一个非常强大的工具&#xff0c;可以用于各种数据分析和机器学习任务&#xff0c;包括分类问题。在Jupyter Notebook中进行分类通常需要以下步骤&#xff1a; 导入所需的库&#xff1a;首先&#xff0c;你需要导入必要的Python库&#xff0c;例如NumPy、Pand…