77. 组合https://leetcode-cn.com/problems/combinations/
难度中等748
给定两个整数 n
和 k
,返回范围 [1, n]
中所有可能的 k
个数的组合。
你可以按 任何顺序 返回答案。
示例 1:
输入:n = 4, k = 2 输出: [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4], ]
示例 2:
输入:n = 1, k = 1 输出:[[1]]
提示:
1 <= n <= 20
1 <= k <= n
通过次数232,718提交次数302,230
class Solution {
public List<List<Integer>> combine(int n, int k) {
//回溯
boolean [] vis = new boolean[n+1];
List<List<Integer>> ans = new ArrayList<List<Integer>>();
List<Integer> temp = new ArrayList<Integer>();
backstack(ans,temp,vis,1,k,n);
return ans;
}
void backstack( List<List<Integer>> ans,List<Integer> temp,boolean [] vis,int index,int k,int n)
{
if(temp.size() == k)
{
ans.add(new ArrayList<Integer>(temp));
return;
}
for(int i=index;i<=n;i++)
{
if(vis[i]==false)
{
vis[i]=true;
temp.add(i);
backstack(ans,temp,vis,i,k,n);
temp.remove(temp.size()-1);
vis[i]=false;
}
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69125.html