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

题目

又到了一年的末尾,项目组让小明负责新年晚会的小礼品发放工作。为使得参加晚会的同时所获得的小礼品价值相对平衡,需要把小礼品根据价格进行分组,但每组最多只能包括两件小礼品,并且每个分组的价格总和不能超过一个价格上限。为了保证发放小礼品的效率,小明需要找到分组数目最少的方案。

你的任务是写一个程序,找出分组数最少的分组方案,并输出最少的分组数目。
输入

第一行数据为分组礼品价格之和的上限

第二行数据为每个小礼品的价格,按照空格隔开,每个礼品价格不超过分组价格和的上限
输出

输出最小分组数量
示例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),查看当前专栏更新的所有题目。

相关推荐
程序员阿鹏2 分钟前
责任链模式
java·spring·servlet·tomcat·maven·责任链模式
@淡 定12 分钟前
Java内存模型(JMM)详解
java·开发语言
czhc114007566336 分钟前
C# 1221
java·servlet·c#
黄俊懿38 分钟前
【深入理解SpringCloud微服务】Seata(AT模式)源码解析——全局事务的回滚
java·后端·spring·spring cloud·微服务·架构·架构师
派大鑫wink44 分钟前
【Day12】String 类详解:不可变性、常用方法与字符串拼接优化
java·开发语言
JIngJaneIL1 小时前
基于springboot + vue健康管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
秋饼1 小时前
【三大锁王争霸赛:Java锁、数据库锁、分布式锁谁是卷王?】
java·数据库·分布式
电商API&Tina1 小时前
【电商API接口】关于电商数据采集相关行业
java·python·oracle·django·sqlite·json·php
刘一说1 小时前
Spring Boot中IoC(控制反转)深度解析:从实现机制到项目实战
java·spring boot·后端
悟空码字1 小时前
SpringBoot参数配置:一场“我说了算”的奇幻之旅
java·spring boot·后端