LeetCode:698. 划分为k个相等的子集

class Solution {

public:

bool canPartitionKSubsets(vector<int>& nums, int k) {

if (k > nums.size())

return false;

int sum = 0;

for (int v : nums) {

sum += v;

}

// 如果数字不能平分

if (sum % k != 0)

return false;

// 记录每个桶中球的数量和

vector<int> bucket(k, 0);

// 每个桶中球的数量,k是分的组数

int target = sum / k;

// 索引值为0,桶中球的数量,桶中的目标数量

return backtrack(nums, 0, bucket, target);

}

bool backtrack(vector<int>& nums, int index, vector<int>& bucket,

int target) {

if (index == nums.size()) {

// 检查是否符合要求

for (int i = 0; i < bucket.size(); i++) {

if (bucketi != target) {

return false;

}

}

return true;

}

//穷举numsindex选择的桶

for(int i=0;i<bucket.size();i++){

if(bucketi+numsindex>target){

continue;

}

bucketi+=numsindex;

if(backtrack(nums, index+1,bucket , target)){

return true;

}

bucketi-=numsindex;

}

return false;

}

};

会超时

相关推荐
JieE21211 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21211 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术16 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦17 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint45619 小时前
C++进阶(1)——前景提要
c++
用户4978630507320 小时前
(一)小红的数组操作
算法·编程语言
夜悊1 天前
C++代码示例:进制数简单生成工具
c++
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
郝学胜_神的一滴1 天前
CMake 021: IF 条件判据详诠
c++·cmake