划分为K个相等的子集
这道题的意思是将数组中的元素分为K个子集,每个子集的和都相等,显然,数组中的元素不能重复使用,而且每个元素都要用到。首先我们来分析一下这道题的解题思路。
思路
- 首先每个子集的总和的值为target=sum(nums)/k ,这个值必须为整数,否则也不符合题意,另外,还有一种情况比较特殊,就是如果数组中的某个值大于target,那肯定也不能满足题意,直接返回false。
- 接下来就是我们应该如何选择每个子集的元素,我们先不想如何写代码,如果让我想的话,先将数组中的元素从第一个开始遍历,如果这个元素的值小于target的话,那么保留当前元素的值,继续遍历下一个元素的值将保留的值加上下一个元素的值的和与target进行比较大小,如果等于target的话,就–K,因为我们已经完成了一个子集对不对,一直向数组的后面继续这样遍历,直到K==0为止,因为这个时候证明所有符合条件的子集都已经找到。
- 下面我们来进行代码实现
class Solution {
public boolean canPartitionKSubsets(int[] nums, int k) {
int sum=0,maxNums=0;
for(int i=0;i<nums.length