华为OD机试题-表演赛游戏分组(java解法)

这篇具有很好参考价值的文章主要介绍了华为OD机试题-表演赛游戏分组(java解法)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、题目

部门准备举办一场王者荣耀表演赛,有 10 名游戏爱好者参与,分 5 为两队,每队 5 人每位参与者都有一个评分,代表着他的游戏水平。
为了表演赛尽可能精彩,我们需要把 10 名参赛者分为实力尽量相近的两队。一队的实力可以表示为这一队5名队员的评分总和。
现在给你 10 名参与者的游戏水平评分,请你根据上述要求分队最后输出这两组的实力差绝对值。
例: 10名参赛者的评分分别为 5 1 8 3 4 6 7 10 9 2,分组为(1 3 5 8 10)(2 4 6 7 9),两组实力差最小,差值为1。有多种分法,但实力差的绝对值最小为 1。

输入

10 个整数,表示 10 名参与者的游戏水平评分。范围在 [1,10000] 之间

输出

1 个整数,表示分组后两组实力差绝对值的最小值

示例一

输入

1 2 3 4 5 6 7 8 9 10

输出

1

二、思路

这道题采用动态规划的方法,想了解动态规划可以阅读这位老哥写的。看一遍就理解:动态规划详解 - 知乎 (zhihu.com)。单看代码不难理解,但是结合题目再看就搞不懂了。直觉告诉我应该分n/2次,怎么代码分了n次。为此我画了一个树状图,一目了然。例子中数组为1、2、3、4,4次分完以后,实际只有6次符合要求。也就是说合理的分法包含在了这里面。时间复杂度是O(2^n)。
现在给你 10 名参与者的游戏水平评分,请你根据上述要求分队,最后输出这两组的实力,华为od,算法,华为od,java,算法

三、题解


import java.util.Scanner;

public class Main {
    static int minDiff = Integer.MAX_VALUE;

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String[] split = scanner.nextLine().split(" ");

        int[] scores = new int[split.length];

        for (int i = 0; i < split.length; i++) {

            scores[i] = Integer.parseInt(split[i]);

        }

        divide(scores, 0, 0, 0);
        System.out.println(minDiff);
    }


    public static void divide(int[] scores, int i, int sum1, int sum2) {

        if (i == scores.length ) {
            minDiff = Math.min(minDiff, Math.abs(sum1 - sum2));
            return;
        }
        divide(scores, i + 1, sum1 + scores[i], sum2);
        divide(scores, i + 1, sum1, sum2 + scores[i]);
    }

}

注:题目来自梦想橡皮擦文章来源地址https://www.toymoban.com/news/detail-852689.html

到了这里,关于华为OD机试题-表演赛游戏分组(java解法)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 华为OD机试题,用 Java 解【蛇形矩阵】问题

    华为OD机试 - 猴子爬山 | 机试题算法思路 【2023】 华为OD机试 - 分糖果(Java) | 机试题算法思路 【2023】 华为OD机试 - 非严格递增连续数字序列 | 机试题算法思路 【2023】 华为OD机试 - 消消乐游戏(Java) | 机试题算法思路 【2023】 华为OD机试 - 组成最大数(Java) | 机试题算法思

    2023年04月09日
    浏览(37)
  • 华为OD机试题,用 Java 解【最远足迹】问题

    华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南 华为od机试,独家整理 已参加机试人员的实战技巧 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单 华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典 使用说明 参加华为od机试,一定要注意不要

    2023年04月23日
    浏览(39)
  • 华为OD机试题,用 Java 解【去除多余空格】问题

    华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南 华为od机试,独家整理 已参加机试人员的实战技巧 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单 华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典 使用说明 参加华为od机试,一定要注意不要

    2024年02月10日
    浏览(45)
  • 华为OD机试题,用 Java 解【星际篮球争霸赛】问题

    华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南 华为od机试,独家整理 已参加机试人员的实战技巧 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单 华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典 使用说明 参加华为od机试,一定要注意不要

    2024年02月07日
    浏览(54)
  • 华为OD机试 -矩阵扩散(Java) | 机试题+算法思路+考点+代码解析 【2023】

    存在一个mn的二维数组,其成员取值范围为0或1。其中值为1的成员具备扩散性,每经过1S,将上下左右值为0的成员同化为1。二维数组的成员初始值都为0,将第[i,j]和[k,l]两个个位置上元素修改成1后,求矩阵的所有元素变为1需要多长时间。 输入描述: 输出数据中的前2个数字表

    2024年02月16日
    浏览(61)
  • 华为OD机试 - 小朋友分组最少调整次数(Java & JS & Python & C)

    题目描述 n 个学生排成一排,学生编号分别是 1 到 n,n 为 3 的整倍数。 老师随机抽签决定将所有学生分成 m 个 3 人的小组(n == 3 * m) , 为了便于同组学生交流,老师决定将小组成员安排到一起,也就是同组成员彼此相连,同组任意两个成员之间无其它组的成员。 因此老师

    2024年02月03日
    浏览(47)
  • 华为OD机试题,用 Java 解【和最大子矩阵】问题 | 含解题说明

    华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南 华为od机试,独家整理 已参加机试人员的实战技巧 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单 华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典 给定一个二维整数矩阵,要在这个矩阵中

    2023年04月11日
    浏览(41)
  • 华为OD机试 -矩阵最大值(Java) | 机试题+算法思路+考点+代码解析 【2023】

    给定一个仅包含0和1的N*N二维矩阵,请计算二维矩阵的最大值,计算规则如下: 1、 每行元素按下标顺序组成一个二进制数(下标越大越排在低位),二进制数的值就是该行的值。矩阵各行值之和为矩阵的值。 2、允许通过向左或向右整体循环移动每行元素来改变各元素在行中

    2024年02月13日
    浏览(56)
  • 【华为OD机试真题 Java语言】68、矩阵扩散 | 机试题+算法思路+考点+代码解析

    🍂个人博客首页: KJ.JK   🍂专栏介绍: 华为OD机试真题汇总,定期更新华为OD各个时间阶段的机试真题,每日定时更新,本专栏将使用Java语言进行更新解答,包含真题,思路分析,代码参考,欢迎大家订阅学习 🎃题目描述 存在一个m*n的二维数组,其成员取值范围为0或1  

    2024年02月14日
    浏览(53)
  • 【免费题库】华为OD机试 - 小朋友分组最少调整次数(Java & JS & Python & C & C++)

    哈喽,本题库完全免费,收费是为了防止被爬,大家订阅专栏后可以私信联系退款。感谢支持 n 个学生排成一排,学生编号分别是 1 到 n,n 为 3 的整倍数。 老师随机抽签决定将所有学生分成 m 个 3 人的小组(n == 3 * m) , 为了便

    2024年04月12日
    浏览(77)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包