1.题目描述
给定一个只包含正整数的非空数组。是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。
注意:
每个数组中的元素不会超过 100
数组的大小不会超过 200
示例 1:
输入: [1, 5, 11, 5]
输出: true
解释: 数组可以分割成 [1, 5, 5] 和 [11].
示例 2:
输入: [1, 2, 3, 5]
输出: false
解释: 数组不能分割成两个元素和相等的子集.
2.解题思路
首先可以将本题转换为01 背包问题。为什么可以转换成01背包问题呢?
这道问题是我学习背包问题的入门问题,做这道题需要做一个等价转换:是否可以从输入数组中挑选出一些正整数,使得这些数的和 等于 整个数组元素的和的一半。很坦白地说,如果不是老师告诉我可以这样想,我很难想出来。容易知道:数组的和一定得是偶数。
本题与 0-1 背包问题有一个很大的不同,即:
- 0-1 背包问题选取的物品的容积总量 不能超过 规定的总量;
- 本题选取的数字之和需要 恰好等于 规定的和的一半。
0 - 1 背包问题的思路:
作为0-1 背包问题,它的特点是:「每个数只能用一次」。解决的基本思路是:物品一个一个选,容量也一点一点增加去考虑,这一点是动态规划的思想,特别重要。
在实际生活中,我们也是这样做的,一个一个地尝试把候选物品放入「背包」,通过比较得出一个物品要不要拿走。具体做法是:画一个 len 行,target + 1 列的表格。这里 len