划分为k个相等的子集

划分为k个相等的子集

题目:

给定一个整数数组 nums 和一个正整数 k,找出是否有可能把这个数组分成 k 个非空子集,其总和都相等。

示例 1:

输入: nums = 4, 3, 2, 3, 5, 2, 1, k = 4

输出: True

说明: 有可能将其分成 4 个子集(5),(1,4),(2,3),(2,3)等于总和。

示例 2:

输入: nums = 1,2,3,4, k = 3

输出: false

解题思路:通过 dfs 进行解答,先计算出每一个子集的总和,然后再通过 dfs 去遍历所有组合

java 复制代码
class Solution {
    private boolean[] book;
    public boolean canPartitionKSubsets(int[] nums, int k) {
        int sum = 0;
        for(int num : nums) {
            sum += num;
        }

        if(sum % k != 0) {
            return false;
        }

        int target = sum / k;
        book = new boolean[nums.length];

        Arrays.sort(nums);
        if(nums[nums.length - 1] > target) {
            return false;
        }

        return dfs(nums, 0, target, 0, k, 0);
    }

    private boolean dfs(int[] nums, int cur, int target, int count, int k, int sum) {
        if(count == k) {
            return true;
        }

        if(sum == target) {
            return dfs(nums, 0, target, count + 1, k, 0);
        }

        for(int i = cur; i < nums.length; i++) {
            if(book[i] || sum + nums[i] > target) {
                continue;
            }

            if(i > cur && nums[i] == nums[i - 1] && !book[i - 1]) {
                continue;
            }

            book[i] = true;
            if(dfs(nums, i + 1, target, count, k, sum + nums[i])) {
                return true;
            }

            book[i] = false;
        }

        return false;
    }
}
相关推荐
智者知已应修善业1 小时前
【51单片机串口通信甲机四个按键模拟四位二进制值发送乙机以十进制显示2位数码管】2024-6-14
c++·经验分享·笔记·算法·51单片机
不会就选b1 小时前
算法日常・每日刷题--<二分查找>2
算法
郝学胜_神的一滴1 小时前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
数据结构·算法
coding者在努力1 小时前
【无标题】
算法
兰令水1 小时前
leecodecode【面试150】【2026.6.15打卡-java版本】
java·算法·面试
WWW65262 小时前
代码随想录 打卡第五十八天
开发语言·c++·算法
pen-ai2 小时前
【HistGBM 系列①】从决策树到梯度提升 —— GBDT 原理精讲
算法·决策树·机器学习
Black蜡笔小新2 小时前
零代码私有化自动化AI算法训练服务器DLTM如何破解企业AI落地难题
人工智能·算法·自动化
liulilittle2 小时前
回归物理本质:对拥塞控制实验室依赖与公平性误置的反思
网络·tcp/ip·计算机网络·算法·tcp·通信·拥塞控制