LeetCode 77.组合
2023-12-13 18:04:47
题目:
给定两个整数?n
?和?k
,返回范围?[1, n]
?中所有可能的?k
?个数的组合。
你可以按?任何顺序?返回答案。
方法:灵神-组合型回溯 剪枝
class Solution {
private int k;
private final List<Integer> path = new ArrayList<>();
private final List<List<Integer>> ans = new ArrayList<>();
public List<List<Integer>> combine(int n, int k) {
this.k = k;
dfs(n);
return ans;
}
private void dfs(int i) {
int d = k - path.size(); // 还要选d个数
if (d == 0) {
ans.add(new ArrayList<>(path));
return;
}
if (d < i) // 不选i
dfs(i - 1);
// 选i
path.add(i);
dfs(i - 1);
path.remove(path.size() - 1);
}
}
文章来源:https://blog.csdn.net/qq_57349657/article/details/134899424
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!