【华为OD机考真题】- 星际篮球争霸赛(Java)

1. 题目描述

具体题目描述如下:

在星球争霸篮球赛对抗赛中,最大的宇宙战队希望每个人都能拿到 MVP,MVP 的条件是单场最高分得分获得者。

可以并列,所以宇宙战队决定在比赛中,尽可能让更多队员上场,并且让所有得分的选手得分都相同,然而比赛过程中的每1分钟的得分都只能由某一个人包揽。

2. 输入描述

输入第一行为一个数字 t,表示为有得分的分钟数 1<=t <= 50,

第二行为t个数字,代表每一分钟的得分p,1<=t <= 50.

3. 输出描述

输出有得分的队员都是 MVP 时,最少得 MVP 得分。

4. 示例演示

4.1 示例1

输入:

复制代码
9
5 2 1 5 2 1 5 2 1

输出:

复制代码
6

示例说明: 样例解释 一共 4人得分,分别都是6分:5+1,5+1,5+1,2+2+2。

Java代码

java 复制代码
package odTest;

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

public class interstellarBasketball {
//	static int countPerson = 0;
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		int num = Integer.parseInt(scanner.nextLine());
		int[] scores = Arrays.stream(scanner.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();
		
		int[] hasUsed = new int[num];
		Arrays.fill(hasUsed, -1);
		int sum = Arrays.stream(scores).sum();
//		System.out.println(sum);
		for(int i=5;i>0;i--) {
			int remain = sum%i;
			if(remain!=0) {
				continue;
			}
//			System.out.println(sum/i);
			boolean flag = judgeMinEvenScore(scores,hasUsed,sum/i,i,0);
			if(flag) {
				System.out.println(sum/i);
				break;
			}
		}
	}

	private static boolean judgeMinEvenScore(int[] scores, int[] hasUsed, int evenScore,int PersonNum,int currentScore) {
		if(currentScore>evenScore) {
			return false;
		}
//		if(countPerson>PersonNum) {
//			return false;
//		}
		if(currentScore == evenScore && !Arrays.stream(hasUsed).anyMatch(m->m==-1)) {
			return true;
		}else if(currentScore == evenScore) {
//			countPerson++;
			currentScore = 0;
		}
		
		for(int i=0;i<scores.length;i++) {
			if(hasUsed[i]==0) {
				continue;
			}
			hasUsed[i] = 0;
			currentScore = currentScore+scores[i];
			boolean flag = judgeMinEvenScore(scores,hasUsed,evenScore,PersonNum,currentScore);
			if(flag) {
				return flag;
			}
			hasUsed[i] = -1;
			currentScore = currentScore-scores[i];
		}
		return false;
	}

}
相关推荐
FQNmxDG4S7 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
虹科网络安全8 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje8 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv79 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫9 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287929 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本9 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
yaoxin5211239 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
极客先躯11 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户606487671889611 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java