【华为OD】MVP争夺战(C++、Java、Python)

文章目录

  • 题目描述
    • 输入描述
    • 输出描述
    • 示例
  • 解题思路
    • 算法思路
    • 核心步骤
  • 代码实现
    • C++实现
    • Java实现
    • Python实现
  • 算法要点
  • 复杂度分析
  • 解题总结

题目描述

在星球争霸篮球赛对抗赛中,最大的宇宙战队希望每个人都能拿到MVP,MVP的条件是单场最高分得分获得者。可以并列所以宇宙战队决定在比赛中尽可能让更多队员上场,并且让所有得分的选手得分都相同,然而比赛过程中的每1分钟的得分都只能由某一个人包揽。

输入描述

  • 第一行为一个数字 t,表示为有得分的分钟数 1 ≤ t ≤ 50
  • 第二行为 t 个数字,代表每一分钟的得分 p,1 ≤ p ≤ 50

输出描述

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

示例

输入:

9
5 2 1 5 2 1 5 2 1

输出:

6

说明:
一共 4 人得分,分别都是 6 分:5 + 1,5 + 1,5 + 1,2 + 2 + 2

解题思路

这是一个数组划分问题,目标是将给定的分数数组分成若干个子集,使得每个子集的和都相等,且子集数量尽可能多(MVP人数最多),这样每个MVP的得分就最小。

算法思路

  1. 贪心策略:为了让MVP人数最多,需要让每个MVP的得分尽可能小
  2. 枚举验证:从最大可能的MVP人数开始尝试,逐步减少直到找到可行解
  3. 回溯分组:使用回溯算法将分数分配到不同的组中,每组代表一个MVP

核心步骤

  1. 计算总分,降序排列数组
  2. 从最大MVP人数开始枚举
  3. 对每个人数,检查总分能否整除
  4. 使用回溯算法验证是否能平均分组
  5. 返回第一个可行方案的单人得分

代码实现

C++实现

#include <iostream>
#include <vector>
#include <algorithm>
#include <numeric>
using namespace std;bool canPartition(vector<int>& nums, int target, int k) {int n = nums.size();vector<int> groups(k, 0);function<bool(int)> dfs = [&](int idx) -> bool {if (idx == n) return true;for (int i = 0; i < k; i++) {if (i > 0 && groups[i] == groups[i-1]) continue;if (groups[i] + nums[idx] <= target) {groups[i] += nums[idx];if (dfs(idx + 1)) return true;groups[i] -= nums[idx];}if (groups[i] == 0) break;}return false;};return dfs(0);
}int main() {int n;cin >> n;vector<int> nums(n);for (int i = 0; i < n; i++) {cin >> nums[i];}int sum = accumulate(nums.begin(), nums.end(), 0);sort(nums.begin(), nums.end(), greater<int>());for (int target = nums[0]; target <= sum; target++) {if (sum % target == 0) {int k = sum / target;if (canPartition(nums, target, k)) {cout << target << endl;return 0;}}}return 0;
}

Java实现

import java.util.LinkedList;
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt();LinkedList<Integer> link = new LinkedList<>();for (int i = 0; i < m; i++) {link.add(sc.nextInt());}System.out.println(getResult(link, m));}public static int getResult(LinkedList<Integer> link, int m) {link.sort((a, b) -> b - a);int sum = 0;for (Integer ele : link) {sum += ele;}while (m >= 1) {LinkedList<Integer> linkCopy = new LinkedList<>(link);if (canPartition(linkCopy, sum, m)) return sum / m;m--;}return sum;}public static boolean canPartition(LinkedList<Integer> link, int sum, int m) {if (sum % m != 0) return false;int target = sum / m;if (target < link.get(0)) return false;while (link.size() > 0 && link.get(0) == target) {link.removeFirst();m--;}int[] groups = new int[m];return dfs(link, 0, groups, target);}public static boolean dfs(LinkedList<Integer> link, int index, int[] groups, int target) {if (index == link.size()) return true;int select = link.get(index);for (int i = 0; i < groups.length; i++) {if (i > 0 && groups[i] == groups[i - 1]) continue;if (select + groups[i] <= target) {groups[i] += select;if (dfs(link, index + 1, groups, target)) return true;groups[i] -= select;}}return false;}
}

Python实现

def dfs(arr, groups, index, target):if index == len(arr):return Truefor i in range(len(groups)):if groups[i] + arr[index] <= target:groups[i] += arr[index]if dfs(arr, groups, index + 1, target):return Truegroups[i] -= arr[index]if groups[i] == 0:breakreturn Falsen = int(input())
arr = list(map(int, input().split()))
total_sum = sum(arr)
arr.sort(reverse=True)for target in range(arr[0], total_sum + 1):if total_sum % target == 0:group_count = total_sum // targetgroups = [0] * group_countif dfs(arr, groups, 0, target):print(target)break

算法要点

核心思想:

  • 将数组分成k个和相等的子集,使k尽可能大
  • 使用回溯算法将元素分配到不同组中
  • 从最优解开始搜索,找到第一个可行解

剪枝优化:

  1. 相同组剪枝:相同容量的组只尝试第一个
  2. 空组剪枝:如果空组放不下,跳过后续空组
  3. 预处理:先处理等于目标值的元素
  4. 排序优化:大元素优先处理,便于剪枝

复杂度分析

  • 时间复杂度:O(k^n),k为组数,n为元素个数
  • 空间复杂度:O(k),用于存储各组当前和

解题总结

MVP争夺战本质上是数组划分问题,通过贪心策略确定搜索方向,回溯算法验证可行性,结合多种剪枝技巧提高效率。关键是理解问题的数学本质:寻找最大的k值,使得数组能被分成k个和相等的子集。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/90859.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/90859.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Datawhale 2025 AI夏令营 MCP Server Task2

魔搭MCP &Agent赛事&#xff08;MCP Server开发&#xff09;/夏令营&#xff1a;动手开发MCP Server学习链接&#xff1a;魔搭MCP &Agent赛事&#xff08;MCP Server开发&#xff09; - Datawhale Task1回顾 1.task1应用功能 luner_info每日黄历 这是一个可以获取某天…

敏捷开发方法全景解析

核心理念:敏捷开发是以快速响应变化为核心的项目管理方法论,通过迭代式交付、自组织团队和持续反馈,实现高质量软件的高效交付。其本质是拥抱变化优于遵循计划,强调"可工作的软件高于详尽的文档"。 一、敏捷核心思想体系 #mermaid-svg-y7iyWsQGVWn3IpEi {font-fa…

Socket到底是什么(简单来说)

简单来说&#xff1a; Socket 抽象了网络通信的复杂底层细节&#xff0c;让应用程序开发者可以专注于发送和接收数据&#xff0c;而不用去操心数据在网络上是如何传输的。 它就像一个“黑盒子”&#xff0c;你只需要把数据扔进去&#xff0c;或者从里面取数据&#xff0c;至于数…

linux系统mysql性能优化

1、系统最大打开文件描述符数查看限制 ulimit -n更改配置 # 第一步 sudo vim /etc/security/limits.conf* soft nofile 1048576 * hard nofile 1048576# 第二步 sudo vim /etc/sysctl.conffs.file-max 1048576# 第三步&#xff08;重启系统&#xff09; sudo reboot验证生效 u…

免费的需要尝试claude code的API安利,截至今天可用(7月13号)

安装方法放最后&#xff08;很简单&#xff0c;但是你得搞定网络&#xff09; 注册如下&#xff1a; 链接如下&#xff08;有详细说明&#xff09;&#xff1a; &#x1f680; AnyRouter&#xff5c;Claude Code 免费共享平台 安装&#xff08;windows用户特殊点&#xff0…

Java 属性配置文件读取方法详解

Java 属性配置文件读取方法详解 一、配置文件基础概念 1. 配置文件类型对比类型格式优点缺点适用场景Propertieskeyvalue简单易读&#xff0c;Java原生支持不支持层级结构简单配置&#xff0c;JDBC参数XML标签层级结构结构化强&#xff0c;支持复杂数据类型冗余&#xff0c;解析…

NW728NW733美光固态闪存NW745NW746

美光NW系列固态闪存深度解析&#xff1a;NW728、NW733、NW745与NW746的全方位评测技术架构与核心创新美光NW系列固态闪存&#xff08;包括NW728、NW733、NW745、NW746&#xff09;的技术根基源于其先进的G9 NAND架构。该架构通过5纳米制程工艺和多层3D堆叠技术&#xff0c;在单…

【面试八股文】2025最新软件测试面试

一、测试基础 1、测试策略或测试包括哪些&#xff0c;测试要覆盖哪些方面 UI、功能、性能、可靠性、易用性、兼容性、安全性、安装卸载 2、设计测试用例的办法 等价类、边界值、错误推测法、场景法等设计方法来编写测试用例的 &#xff08;1&#xff09;等价类分为有效等价…

AI软件出海SEO教程

一、出海SEO核心思路 本地化&#xff1a;内容、技术、用户体验全面适应目标市场。关键词策略&#xff1a;围绕目标用户的真实搜索习惯做关键词挖掘和布局。内容为王&#xff1a;持续输出高质量、解决用户痛点的内容。技术优化&#xff1a;保证网站速度、结构、移动端体验及安全…

PyVision:基于动态工具的具身智能体

论文地址&#xff1a; [2507.07998v1] PyVision: Agentic Vision with Dynamic Tooling 1. 背景 现有的智能体一般都是通过大模型规划调用已经预定义好的一些工具&#xff08;具体来说也就是一些函数&#xff09;来解决问题。这样就会导致在针对特征的任务上Agent去解决问题…

Higress 上架 KubeSphere Marketplace,助力企业构建云原生流量入口

随着企业数字化转型持续深化&#xff0c;云原生架构正逐渐成为构建现代应用的主流选择。而服务治理作为云原生落地的核心能力之一&#xff0c;急需更灵活、高效的解决方案。近日&#xff0c;AI 原生的 API 网关 Higress 正式上架 KubeSphere Marketplace&#xff0c;助力用户轻…

在LC480T上部署xapp1052

实验环境&#xff1a;LC480T加速卡 开发环境&#xff1a;windows11vivado2020 运行环境&#xff1a;ubuntu22.04 硬件电路&#xff1a;LC480T加速卡(xc7k480tffg1156-2) vivado工程文件下载&#xff1a;https://download.csdn.net/download/xiaolangyangyang/91349686 驱动及应…

TCP的socket编程

TCP客户端逻辑void Usage(const std::string & process) {std::cout << "Usage: " << process << " server_ip server_port" <<std::endl; } // ./tcp_client serverip serverport int main(int argc, char * argv[]) {if (ar…

【理念●体系】模板规范篇:打造可标准化复用的 AI 项目骨架

【理念●体系】从零打造 Windows WSL Docker Anaconda PyCharm 的 AI 全链路开发体系-CSDN博客 【理念●体系】Windows AI 开发环境搭建实录&#xff1a;六层架构的逐步实现与路径治理指南-CSDN博客 【理念●体系】路径治理篇&#xff1a;打造可控、可迁移、可复现的 AI 开…

Skia---渐变色着色器

今天介绍的是实际工作中最常用到的着色器&#xff1a;渐变色着色器。 渐变色着色器是一个从一种颜色平滑的过渡到另一种颜色的效果&#xff0c;渐变色着色器的作用主要是增强图形的视觉吸引力。 线性渐变 Skia 里的线性渐变色着色器是最简单的渐变色着色器&#xff0c;它用于…

2025.07.09华为机考真题解析-第二题200分

📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 02. 地铁线路故障预警系统 问题描述 LYA 负责管理一个城市的地铁网络系统。地铁网络由 n n n

数学建模:非线性规划:凸规划问题

一、定义凸集定义​​&#xff1a;设Ω是n维欧氏空间的一点集&#xff0c;若任意两点x₁∈Ω&#xff0c;x₂∈Ω&#xff0c;其连线上的所有点αx₁(1-α)x₂∈Ω&#xff0c;(0≤α≤1)&#xff0c;则称Ω为凸集。​​凸函数定义​​&#xff1a;给定函数f(x)(x∈D⊂Rⁿ)&…

ISIS | 广播网络中的 ISIS 伪节点 LSP

注&#xff1a;本文为 “ISIS | 伪节点 LSP” 相关合辑。 英文引文&#xff0c;机翻未校。 中文引文&#xff0c;略作重排。 如有内容异常&#xff0c;请看原文。 ISIS in Broadcast Network and Pseudonode LSP 广播网络中 的 ISIS 伪节点 LSP ISIS in broadcast network is…

ARIA UWB安全雷达主要产品型号与核心功能全解析

ARIA UWB雷达拥有LT系列与AHM系列两大产品线。LT103 XBT、LT102 V2、LT103 OEM等代表型号具备高精度定位、低功耗和强穿透能力&#xff0c;适用于工业自动化与物联网。AHM3D、AHM2D、AHM3DSC则专注三维检测和智能计算&#xff0c;广泛服务于医疗健康、安防监控等场景。Hydrogen…

NLP自然语言处理04 transformer架构模拟实现

总体架构输入部分代码实现:导包# -*-coding:utf-8-*- import matplotlib.pyplot as plt import numpy as np import torch import torch.nn as nn # -*-coding:utf-8-*- import copy import torch.nn.functional as F import math位置编码器部分词嵌入WordEmbedding# todo 作用…