把一个数组分为两部分使得其和相差最小——Java实现(详细注释,全面解析)

package bag;public class Test {/*** 给一个整数数组 array,把他分为两部分 a 和 b* 使得 a 和 b 的元素之和的差最小** @param array 输入数组* @return 返回差值最小是多少* <p>* 解析:array分出来的两个数组a、b之和sum1、sum2等于总和SUM* 既然要 sum1 与 sum2 之间相差最小则他们应该尽量接近 SUM/2* <p>* 即问题转变为:在array中取出数据存入a中,在不超过 SUM/2 的情况下使得a的总和最大* <p>* 也就是0-1背包问题*/public static int getTwoSubArrayMinDiff(int[] array) {int ans = 0;if (array.length == 0)return ans;int n = array.length;int SUM = 0;for (int i = 0; i < n; i++) {SUM += array[i];}// 状态转移方程:设待选的各个数据为 i,容量为 SUM/2,// dp[i][c] = max( dp[i-1][c], dp[i-1][C-c[i]] + c[i])/*解释:c 就是 capacity,每次从array里面取走一个数据,存在: 放入新数组a里面和不放入新数组里面a 两个选择不管是否放入i值都少了一个:i-1* 放入的时候:不仅要给 i 值减一,且将a中剩余可存入的数量减少响应值,即 C-c[i] (总容量减去已存入的等于剩余的)* 不放入的时候:仅需将i减一即可那么以上两种情况选择哪一种会导致a的和最接近 SUM/2 呢?使用max取本次dp[i][c]的最大值即可*/int[][] dp = new int[n + 1][SUM / 2 + 1];/*本题并不完全是一个背包问题,这里没有价值只有重量,也就是每一个数组元素的值。外层循环从0开始也行从1开始也行,注意别越界就可以了,内层循环每来一次,就得重新计算 dp[i][1...C] 的值,内层循环的含义是:每次从array里面拿到一个数据后要考虑是否放到新数组a里面,那么就得计算该元素放入是否能加入到a以及能否获取最大收益。最终不管是否加入了a,该元素都不再考虑。那么内层循环里面通过不断改变背包的容量(从1到SUM/2)来确定是否能产生最大收益*/for (int i = 0; i < n; i++) {for (int j = 1; j <= SUM / 2; j++) { // 假设当前的背包容量是 j// 这是不放入背包的情况dp[i + 1][j] = dp[i][j];// 这是放入背包的情况if (array[i] <= j // 先要确保array[i]的值不能大于背包容量&& dp[i][j - array[i]] + array[i] > dp[i][j]) { // 然后可以放心的把当前物品放入背包dp[i + 1][j] = dp[i][j - array[i]] + array[i];}// dp[i + 1][j] 会得到一个最大值}}// dp[n][SUM / 2] 是新数组a的和,他的两倍应该近似于SUM,差值即为两个新数组a、b之间的和最小差return SUM - 2 * dp[n][SUM / 2];}public static void main(String[] args) {
//        int[] array = {2, 3, 4, 6};
//        int[] array = {5, 6, 8, 7};int[] array = {25, 0, 18, 3, 9, 4, 12, 7, 6, 11};System.out.println(getTwoSubArrayMinDiff(array));System.out.println(getTwoSubArrayMinDiff2(array));}public static int getTwoSubArrayMinDiff2(int[] array) {if (array.length == 0) {return 0;}int sum = 0;for (int x : array) {sum += x;}int n = array.length;// 状态转移方程int[][] dp = new int[n][sum / 2 + 1];// 首先检查 0 号元素是否可以存入背包for (int i = 0; i <= sum / 2; i++ ) {dp[0][i] = (i >= array[0]) ? array[0] : 0;}// 然后再动态规划处理for (int i = 1; i < n; i++) {for (int j = 0; j <= sum / 2; j++) {dp[i][j] = dp[i - 1][j];// 若剩余空间可以存入当前的array[i]if (j >= array[i]) {dp[i][j] = Math.max(dp[i][j], dp[i - 1][j - array[i]] + array[i]);}}}return sum - 2 * dp[n - 1][sum / 2];}
}

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

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

相关文章

AIGC 005-Dreambooth定制化生成,微调文本到图像的扩散模型!

AIGC 005-Dreambooth定制化生成&#xff0c;微调文本到图像的扩散模型&#xff01; 文章目录 0 论文工作1 论文方法2 效果 0 论文工作 DreamBooth 论文 (DreamBooth: Fine-Tuning Text-to-Image Diffusion Models for Subject-Driven Generation) 提出了一种新颖的技术&#x…

【开源】大学生竞赛管理系统 JAVA+Vue+SpringBoot+MySQL

目录 一、系统介绍 学生管理模块 教师管理模块 竞赛信息模块 竞赛报名模块 二、系统截图 三、核心代码 一、系统介绍 基于Vue.js和SpringBoot的大学生竞赛管理系统&#xff0c;分为管理后台和用户网页端&#xff0c;可以给管理员、学生和教师角色使用&#xff0c;包括学…

mysql实战——xtrabackup全量备份/增量备份及恢复

一、测试前准备 mysql数据库 端口3306数据文件目录 /data/mysql/3306/data 安装目录/usr/lcoal/mysql配置文件/etc/my.cnf 创建数据库 testXtra 创建备份目录 备份目录/data/backup/备份恢复数据文件目录/data/mysql/3307/data备份恢复配置文件/etc/my_3307.cnf 二、开始…

linux查看是否被入侵(一)

1、查看当前系统状态 [rootbastion-IDC ~]#top #一般挖矿等病毒点用CPU比较大 2、查看当前登录用户(w\who) 3、检查系统日志 检查系统错误登陆日志&#xff0c;统计IP重试次数 [rootbastion-IDC ~]# lastb 4、查看近期用户登录情况 [rootkvm01 ~]# last -n 5 #-n 5 表示…

Go 控制协程(goroutine)的并发数量

在使用协程并发处理某些任务时, 其并发数量往往因为各种因素的限制不能无限的增大. 例如网络请求、数据库查询等等。 从运行效率角度考虑&#xff0c;在相关服务可以负载的前提下&#xff08;限制最大并发数&#xff09;&#xff0c;尽可能高的并发。 在Go语言中&#xff0c;…

将list对象里的某一个属性取出组成一个新的list

使用Java8将对象里的某一个属性取出组成一个新的list List<Spgg1> listnew ArrayList<>();Spgg1 spgg1new Spgg1();spgg1.setSpdm("测试");spgg1.setGgdm("001");list.add(spgg1);Spgg1 spgg2new Spgg1();spgg2.setSpdm("测试2");sp…

Mysql 找出未提交事务的SQL及死锁

未提交事务&#xff1a; 通过查看information_schema.INNODB_TRX视图,您可以了解当前系统中正在运行的事务情况,从而进行问题排查和性能优化。 SELECT * FROM information_schema.innodb_trx; 通过trx_state为RUNNIG,trx_started判断是否有一直RUNNING的事务。 如果有未提交…

千帆【API接入】自定义组件简明教程

千帆【API接入】自定义组件简明教程 大家好&#xff0c;我是 JavaRoom&#xff0c;今天来给大家做一个自定义API接入来是心啊遣返组件创建案例简明教学。 1.准备工作 1.1 一个不欠费的千帆账号 财务总览地址&#xff1a;https://console.bce.baidu.com/billing/#/account/i…

“现代汽车中国前瞻软件赛杯” 牛客周赛 Round 43

A. 小红平分糖果&#xff08;签到&#xff09; // Problem: 小红平分糖果 // Contest: NowCoder // URL: https://ac.nowcoder.com/acm/contest/82394/A // Memory Limit: 524288 MB // Time Limit: 2000 ms // // Powered by CP Editor (https://cpeditor.org)#include<b…

作业-day-240524

使用sqlite3数据库&#xff0c;实现增删改查操作 #include <myhead.h>int do_add(sqlite3 *sqdb) {int add_num;char add_name[128];double add_score;printf("请输入要添加的学生编号:");scanf("%d",&add_num);printf("请输入要添加的学生…

以前:不会用电脑;现在:不会用AI

购买特价商务机票需要一些策略和灵活性。、 提前规划&#xff1a;商务舱票价通常在出发日期的2-3个月前最便宜。尽早规划您的行程并开始关注票价。 使用比价工具&#xff1a;使用Skyscanner、Kayak等比价网站来比较不同航空公司的商务舱票价。这些网站可以显示多个航空公司的价…

Jeecg | 如何解决 ERR Client sent AUTH, but no password is set 问题

最近在尝试Jeecg低代码开发&#xff0c;但是碰到了超级多的问题&#xff0c;不过总归是成功运行起来了。 下面说说碰到的最后一个配置问题&#xff1a;连接redis失败 Error starting ApplicationContext. To display the conditions report re-run your application with deb…

【ARMv7-A】——内联汇编

简介 使用内联汇编主要目的是为了提高效率,同时还是为了实现 C 语言无法实现的部分。 GNU内联汇编的基本格式: asm volatile("汇编语句": 输出部分: 输入部分: 会被修改的部分);ANSI C规范的关键字(前后都有两个下划线连接,中间没有空格): __asm__ __volati…

近期阅读论文

Exploring Hybrid Active-Passive RIS-Aided MEC Systems: From the Mode-Switching Perspective abstract 移动边缘计算&#xff08;MEC&#xff09;被认为是支持延迟敏感和计算密集型服务的有前途的技术。 然而&#xff0c;随机信道衰落特性导致的低卸载率成为制约MEC性能的…

Rust之函数、单元测试

1、函数 类似于C函数。 1.1、普通函数 在Rust中&#xff0c;函数的定义使用fn关键字&#xff0c;后跟函数名、参数列表、返回类型和函数体。函数体由一系列语句组成&#xff0c;用于执行特定的操作和计算。 函数定义&#xff1a; 使用fn关键字定义函数&#xff0c;函数由函数…

【C语言】C语言基础语法速览

C语言基础语法目录 C语言基础语法速览1. 变量类型1.1 类型字节数1.1 变量输出格式1.2 变量输入格式 2. 分支循环语句2.1 if分支语句2.2 switch 分支语句2.3 while循环语句2.4 do...while循环语句2.5 for循环语句 3. 数组3.1 一维数组3.2 二维数组 4. 结构体4.1 结构体类型定义4…

4个宝藏网站,免费即用,办公运营效率利器!

哈喽&#xff0c;各位小伙伴们好&#xff0c;我是给大家带来各类黑科技与前沿资讯的小武。 有很多朋友在日常办公时&#xff0c;需要发送邮件&#xff1b;在新媒体运营、设计及前端开发等工作场合中&#xff0c;都或多或少会遇上图片、视频等文件太大及格式问题需要压缩和转换…

数据结构(三)栈 队列 数组

2024年5月26日一稿(王道P78) 栈 基本概念 基本操作 顺序存储结构 基本操作 共享栈

微信小程序开发 懒加载+瀑布流+排序功能

在小程序的开发过程中&#xff0c;遇到了这样的功能需求&#xff1a;在保持瀑布流布局的情况下&#xff0c;使用懒加载来渲染页面&#xff0c;并且要求对其中的属性添加排序功能。 单独拿出来都是很好实现的功能&#xff0c;但是当三个功能联系在一起时&#xff0c;问题就出现…

数智乡村:是不是乡村治理治理的巨大进步呢?

一、什么是数智乡村 数智乡村是指借助信息技术和数据分析等手段&#xff0c;对乡村进行智能化管理和服务的模式。它可以提供更高效、精准、便利的服务&#xff0c;促进乡村经济发展和社会治理改善。因此&#xff0c;数智乡村确实可以被视为乡村治理的巨大进步。 二、数智乡村的…