news 2026/6/22 22:43:03

UVa 562 Dividing Coins

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 562 Dividing Coins

题目描述

题目要求将一堆硬币尽可能公平地分给两个人,即两人所得金额之差最小。硬币不能拆分。输出最小差值。

输入格式

第一行一个整数nnn,表示测试用例的数量。每个测试用例第一行一个整数mmm0≤m≤1000 \le m \le 1000m100),表示硬币数量。第二行mmm个整数,表示每枚硬币的面值(111500500500)。

输出格式

对于每个测试用例,输出一行一个整数,表示两人所得金额的最小差值。

样例

输入

2 3 2 3 5 4 1 2 4 6

输出

0 1

题目分析

本题的核心是子集和问题(subset sum\texttt{subset sum}subset sum)。设总金额为SSS,一人分得xxx,另一人分得S−xS - xSx,差值为∣S−2x∣|S - 2x|S2x。最小化差值等价于找到最接近S/2S/2S/2的子集和。

动态规划

使用0/1\texttt{0/1}0/1背包,dp[j]\textit{dp}[j]dp[j]表示能否凑出金额jjj。初始化dp[0]=true\textit{dp}[0] = \texttt{true}dp[0]=true,然后对每个硬币进行更新。最后从⌊S/2⌋\lfloor S/2 \rfloorS/2向下找到第一个可凑出的金额,差值即为S−2×targetS - 2 \times targetS2×target

复杂度分析

总金额≤100×500=50000\le 100 \times 500 = 50000100×500=50000m≤100m \le 100m100,时间复杂度O(m×S)O(m \times S)O(m×S),空间O(S)O(S)O(S)

代码实现

// Dividing coins// UVa ID: 562// Verdict: Accepted// Submission Date: 2016-08-16// UVa Run Time: 0.000s//// 版权所有(C)2016,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;intmain(){cin.tie(0);cout.tie(0);ios::sync_with_stdio(false);intcoins[110],cents[25010],n,m;cin>>n;for(intc=1;c<=n;c++){inttotal=0;cin>>m;for(inti=1;i<=m;i++){cin>>coins[i];total+=coins[i];}if(m<=1){cout<<total<<'\n';continue;}inthalf=total/2;memset(cents,0,sizeof(cents));for(inti=1;i<=m;i++)for(intj=half;j>=coins[i];j--)cents[j]=max(cents[j],cents[j-coins[i]]+coins[i]);for(inti=half;i>=1;i--)if(cents[i]){cout<<abs(total-2*cents[i])<<'\n';break;}}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 22:34:12

紫光档案管理系统SQL注入漏洞复现:从原理到实战的完整指南

1. 项目概述与背景最近在梳理一些历史遗留系统的安全风险时&#xff0c;紫光档案管理系统的一个老漏洞进入了我的视线。这个漏洞出现在一个名为mergeFile的功能接口中&#xff0c;是一个典型的SQL注入漏洞。虽然这个漏洞可能已经过去了一段时间&#xff0c;相关的补丁或许早已发…

作者头像 李华
网站建设 2026/6/22 22:29:56

超越对齐:任务奖励在LLM强化学习微调中的核心价值与实践

1. 项目概述&#xff1a;当微调不止于对齐如果你最近在折腾大语言模型的微调&#xff0c;尤其是尝试过基于人类反馈的强化学习&#xff08;RLHF&#xff09;或其变种&#xff0c;那你大概率对“分布锐化”这个概念不陌生。简单来说&#xff0c;为了让模型输出更符合人类偏好&am…

作者头像 李华
网站建设 2026/6/22 22:28:30

基于DSP56F805的开关磁阻电机控制:软件架构与工程实践详解

1. 项目概述与核心挑战最近在整理一个老项目的技术文档&#xff0c;翻出来一份基于Motorola&#xff08;现NXP&#xff09;DSP56F805的三相开关磁阻电机&#xff08;SRM&#xff09;控制软件设计手册。虽然这份文档有些年头了&#xff0c;但里面关于如何在资源有限的16位DSP上构…

作者头像 李华
网站建设 2026/6/22 22:22:57

3步解锁开源数学学位:从零基础到范畴论专家的自学革命

3步解锁开源数学学位&#xff1a;从零基础到范畴论专家的自学革命 【免费下载链接】math &#x1f9ee; Path to a free self-taught education in Mathematics! 项目地址: https://gitcode.com/GitHub_Trending/ma/math 想要掌握数学思维却不知从何入手&#xff1f;厌倦…

作者头像 李华
网站建设 2026/6/22 22:21:51

如何高效使用Latest:macOS应用更新管理终极指南

如何高效使用Latest&#xff1a;macOS应用更新管理终极指南 【免费下载链接】Latest A small utility app for macOS that makes sure you know about all the latest updates to the apps you use. 项目地址: https://gitcode.com/gh_mirrors/la/Latest Latest是一款专…

作者头像 李华