当前位置: 首页> 健康> 养生 > [Mdfs] lc473. 火柴拼正方形(剪枝优化+经典题+好题)

[Mdfs] lc473. 火柴拼正方形(剪枝优化+经典题+好题)

时间:2025/8/24 2:14:15来源:https://blog.csdn.net/yl_puyu/article/details/141509551 浏览次数:0次

文章目录

    • 1. 题目来源
    • 2. 题目解析

1. 题目来源

链接:473. 火柴拼正方形

拔高、证明:

  • [dfs] aw167. 木棒(dfs剪枝与优化+分类讨论+思维+好题)

2. 题目解析

水一篇。和之前的一个问题一模一样,在此不再赘述,写出来方便搜索。

  • [Mdfs] lc698. 划分为k个相等的子集(剪枝优化+经典题+好题)

  • 时间复杂度:此类 dfs 和剪枝,不必进行分析
  • 空间复杂度:此类 dfs 和剪枝,不必进行分析

class Solution {
public:bool makesquare(vector<int>& matchsticks) {return canPartitionKSubsets(matchsticks, 4);}bool canPartitionKSubsets(vector<int>& nums, int k) {int n = nums.size();int sum = 0;for (int x : nums) sum += x;int x = sum / k;if (x * k != sum) return false;sort(nums.begin(), nums.end(), greater<int>()); // 剪枝1:从大到小进行搜索vector<bool> st(n, false);function<bool(int, int, int)> dfs = [&](int u, int cur, int cnt) {if (cnt == k) return true;if (cur == x) return dfs(0, 0, cnt + 1);for (int i = u; i < n; i ++ ) { // 从大到小搜索if (st[i]) continue;if (cur + nums[i] > x) continue;// 尝试搜索当前位置st[i] = true;if (dfs(i + 1, cur + nums[i], cnt)) return true;// 搜索当前位置失败的话st[i] = false;while (i + 1 < n && nums[i] == nums[i + 1]) i ++ ; // 剪枝2:搜索的相同元素失败if (!cur || cur + nums[i] == x) return false; // 剪枝3、4:如果搜索的第一个、最后一个失败}return false;};return dfs(0, 0, 0);}
};
关键字:[Mdfs] lc473. 火柴拼正方形(剪枝优化+经典题+好题)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: