【华为OD题库-062】计算礼品发放的最小分组数目-java

news/2024/7/20 19:09:32 标签: java, 华为od

题目

又到了一年的末尾,项目组让小明负责新年晚会的小礼品发放工作。为使得参加晚会的同时所获得的小礼品价值相对平衡,需要把小礼品根据价格进行分组,但每组最多只能包括两件小礼品,并且每个分组的价格总和不能超过一个价格上限。为了保证发放小礼品的效率,小明需要找到分组数目最少的方案。
你的任务是写一个程序,找出分组数最少的分组方案,并输出最少的分组数目。
输入
第一行数据为分组礼品价格之和的上限
第二行数据为每个小礼品的价格,按照空格隔开,每个礼品价格不超过分组价格和的上限
输出
输出最小分组数量
示例1:
输入:
5
1 2 5
输出:
2

思路

最多只能分两个礼品,要求最小方案数。先将输入nums按从小到大排序,以数据为例:1 2 3 3 5 8(假设不超过8),让left指向第一个礼物1,right指向最后一个礼物8
计算当前礼物价值:8+1=9,超过限制,8只能单独分一组,right- -,res=1
left=1,right=5,和为6,可以分为一组,left++,right- -,res=2
left=2,right=3,可以分为一组,left++,right- -,res=3
left=3,right=3,指向的同一个值,单独分一组即可,res=4
上述过程可以用队列或者双指针模拟实现。

题解

java">package hwod;

import java.util.Arrays;
import java.util.LinkedList;
import java.util.Scanner;

public class GiftGroup {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int max = sc.nextInt();
        sc.nextLine();
        int[] nums = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        System.out.println(giftGroup(nums, max));
        System.out.println(giftGroup2(nums, max));
    }

    private static int giftGroup(int[] nums, int max) {
        Arrays.sort(nums);
        LinkedList<Integer> queue = new LinkedList<>();
        for (int num : nums) {
            queue.addLast(num);
        }
        int res = 0;
        while (queue.size() > 1) {
            int cur = queue.peekLast() + queue.peekFirst();
            queue.removeLast();
            if (cur <= max) {
                queue.removeFirst();
            }
            res++;
        }

        return queue.isEmpty() ? res : res + 1;
    }

    private static int giftGroup2(int[] nums, int max) {
        Arrays.sort(nums);
        int left = 0, right = nums.length - 1, res = 0;
        while (left < right) {
            int cur = nums[right] + nums[left];
            right--;
            res++;
            if (cur <= max) {
                left++;
            }
        }

        return left==right?res+1:res;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。


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

相关文章

基于现代学徒制的大数据技术与应用人才培养模式探讨

学生学徒制的实施旨在解决当前新技术企业招聘技能人才难和青年就业难的结构性矛盾&#xff0c;通过生态链链主企业携手院校共同解决毕业年度学生就业问题&#xff0c;按照学生个人意愿&#xff0c;建立以就业导向的学生学徒制关系&#xff0c;签订学徒培养协议确定学生就业岗位…

PTA 7-230 美好日子

据说2021年12月2日是一个美好日子&#xff0c;因为这是一个完全对称日&#xff01;这里认为一个美好日子是一个共8位数字的完全对称日&#xff08;例如20211202&#xff09;&#xff0c;其中年份占4位&#xff0c;月份、日份都是2位。对于给定的年份&#xff0c;请判断该年是否…

CEPH搭建

目录 一、概述 特点 1、统一存储 2、高扩展性 3、可靠性强 4、高性能 二、准备工作 1、关闭防火墙 2、关闭图形网络管理器 3、配置静态ip 4、关闭selinux 5、修改主机名 6、修改设置 7、ssh免密设置 8、hosts文件修改 9、时间同步 10、添加磁盘&#xff0c;并…

java 多种验证码

java 多种验证码 1.SpringBoot 引入jar包2. java 导入jar包3. 代码4. 效果图 1.SpringBoot 引入jar包 <dependency><groupId>com.github.whvcse</groupId><artifactId>easy-captcha</artifactId><version>1.6.2</version> </dep…

Linux4.8、环境变量续

个人主页&#xff1a;Lei宝啊 愿所有美好如期而遇 前言 如果对环境变量没有基本的理解&#xff0c;那么建议先看完这篇文章&#xff1a;环境变量https://blog.csdn.net/m0_74824254/article/details/134661113?spm1001.2014.3001.5501 环境变量与本地变量区别 使用export设…

k8s部署的四种方案

文章目录 一、基于二进制文件的部署方式1. 准备 k8s 组件2. 安装 kubelet 和 kube-proxy3. 安装 kube-apiserver、kube-controller-manager 和 kube-scheduler4. 验证 k8s 集群 二、使用 kubeadm 工具部署1. 准备节点2. 安装 kubeadm 工具3. 初始化 Master 节点4. 配置 k8s 环境…

无需编程,绿云PMS如何优化用户运营—API连接、集成、广告推广

无需编程的优化艺术&#xff1a;绿云PMS如何改善用户运营 随着科技的进步&#xff0c;企业面临着持续的数字化转型压力。在这个过程中&#xff0c;如何在不增加技术负担的前提下改善用户运营成为一大挑战。杭州绿云软件股份有限公司通过其创新的绿云PMS系统&#xff0c;为企业…

【开源】基于Vue+SpringBoot的数据可视化的智慧河南大屏

项目编号&#xff1a; S 059 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S059&#xff0c;文末获取源码。} 项目编号&#xff1a;S059&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统展示四、核心代码4.1 数据模块 …