题目概述:有一个没有排序,元素个数为2N的正整数数组。要求把它分割为元素个数为N的两个数组,并使两个子数组的和最接近。
假设数组A[1..2N]所有元素的和是SUM。模仿动态规划解0-1背包问题的策略,令S(k, i)表示前k个元素中任意i个元素的和的集合。显然:
S(k, 1) = {A[i] | 1<= i <= k}
S(k, k) = {A[1]+A[2]+…+A[k]}
S(k, i) = S(k-1, i) U {A[k] + x | x属于S(k-1, i-1) }
按照这个递推公式来计算,最后找出集合S(2N, N)中与SUM最接近的那个和,这便是答案。这个算法的时间复杂度是O(22N).
因为这个过程中只关注和不大于SUM/2的那个子数组的和。所以集合中重复的和以及大于SUM/2的和都是没有意义的。把这些没有意义的和剔除掉,剩下的有意义的和的个数最多就是SUM/2个。所以,我们不需要记录S(2N,N)中都有哪些和,只需要从SUM/2到1遍历一次,逐个询问这个值是不是在S(2N,N)中出现,第一个出现的值就是答案。我们的程序不需要按照上述递推公式计算每个集合,只需要为每个集合设一个标志数组,标记SUM/2到1这个区间中的哪些值可以被计算出来。关键代码如下:
for(i = 0; i < N+1; i++)
for(j = 0; j < sum/2+1; j++)
flag[i][j] = false;
flag[0][0] = true;
for(int k = 1; k <= 2*N; k++) {
for(i = k > N ? N : k; i >= 1; i--) {
//两层外循环是遍历集合S(k,i)
for(j = 0; j <= sum/2; j++) {
if(j >= A[k] && flag[i-1][j-A[k]])
flag[i][j] = true;
}
}
}
for(i = sum/2; i >= 0; i--) {
if(flag[N][i]) {
cout << "minimum delta is " << abs(2*i - sum) << endl;
break;
}
}
分享到:
相关推荐
该问题源于《编程之美》中的2.18章节,同时也是July的《微软等公司面试100题》中的32题,主要探讨如何通过交换两个序列的元素,使得两个序列元素之和的差最小。这个问题的关键在于找到一种有效的交换策略,使得两个...
在Linux操作系统中,glibc(GNU C Library)是核心的库组件之一,它为应用程序提供了丰富的C语言编程接口,包括基本的数据类型、输入/输出、字符串处理、内存管理、线程支持等。glibc-2.18是glibc的一个重要版本,...
联想G460是一款较早的笔记本电脑型号,其BIOS V2.18的更新是针对该设备的一个关键升级。 首先,我们要理解BIOS的主要功能。它包括但不限于检测和初始化硬件组件,如CPU、内存、硬盘、显卡等;设置启动顺序,让用户...
这可能涉及到网络编程、逆向工程、安全策略分析等多个技术领域。 在文件列表中,我们看到一个名为“QX模块 v2.18更新版 QQ强红包防撤回利器.txt”的文本文件。这个文件很可能是使用说明、更新日志或者安装指南,...
Struts2.18是Apache Struts框架的一个版本,它是一个基于MVC(Model-View-Controller)设计模式的开源Java Web应用框架。这个框架的主要目的是为了帮助开发者构建结构清晰、易于维护的Web应用程序。在"struts2.18 ...
XWork是Struts 2的基础,提供了一套强大的动作框架,支持AOP(面向切面编程)和数据绑定。 2. **freemarker-2.3.15.jar**:FreeMarker是一个模板引擎,用于生成动态内容,例如HTML页面。Struts 2使用FreeMarker作为...
glibc-2.18是glibc的第2.18次更新,它包含了大量的优化和新特性,以支持最新的编程需求和硬件平台。 **glibc的概述:** glibc是GNU项目的一部分,由自由软件基金会(FSF)维护。它是Linux及其他类UNIX系统中最广泛...
总之,Git 2.18 for Windows x64是开发者必备的工具之一,无论你是初学者还是资深开发者,都能从中受益。通过下载这个压缩包,你可以快速获取到Git的最新版本,节省下载时间,提高工作效率。在使用过程中,不断探索...
glibc是Linux系统中最基础且最重要的库之一,它为应用程序提供了标准C接口和许多其他系统服务。 glibc: 1. **定义**:glibc是GNU项目开发的C库,它是Linux和其他类UNIX系统上广泛使用的标准C库,包含了C语言的基本...
rufus-2.18.zip
gtk+-2.18.2.tar版本下载,2.18.2是比较稳定的版本
使用美萍VOb点播软件时,需要的一款小插件。
ProxifierMac2.18 含注册码,请详细看压缩包描述,SN注册码说明
- **定义处理函数**:通过 `websUrlHandlerDefine()` 定义 URL 处理函数,这些函数存储在数组 `websUrlHandler[websUrlHandlerMax]` 中。 - **匹配处理函数**:根据请求的 URL 前缀匹配合适的处理函数,如果未找到...
文件名中的数字"3"可能是发行序列号或者更新迭代的标识,这表明可能有多个版本或补丁发布于2.18.0版本之下。 在安装Git时,用户需要选择安装路径、配置默认编辑器、设置SSH密钥等选项。安装完成后,可以通过命令行...
rufus-2.18p U盘引导盘制作工具,多用于较原始的Windows安装系统的那种方法,由于现在FAT的盘都限制文件大小为4.25G。要么改格式用pe装,要么就制作分区盘。rufus大小不到1M,无比纯净,非常好使。
pandoc-2.18-windows-x86_64 Windows zip压缩包! Pandoc是标记语言转换工具,可实现不同标记语言间的格式转换,堪称该领域中的“瑞士军刀”。 Pandoc使用Haskell语言编写,以命令行形式实现与用户的交互,可支持...
`GLIBC_2.18`是一个特定版本的glibc符号,表明程序需要至少版本2.18的glibc才能运行。当你遇到错误提示“/lib64/libc.so.6: version `GLIBC_2.18' not found”,这意味着你的系统中的glibc版本低于2.18,而你尝试...
GLIBC,全称GNU C Library,是Linux系统中最核心的库之一,提供C语言编程所需的接口和服务。当遇到"libc.so.6: version `GLIBC_2.14' not found"这样的错误时,通常意味着运行的程序依赖于至少GLIBC 2.14版的某些...
《Abraxas Software的PCYACC 2.18:dos时代的编程利器》 在早期的个人计算机时代,操作系统和开发工具相对简单,但依然有众多程序员致力于创新和改进。Abraxas Software的PCYACC 2.18便是那个时期的一颗璀璨明珠,...