按顺序进行组合即可
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param n int整型 * @param k int整型 * @return int整型ArrayList<ArrayList<>> */ ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>>(); LinkedList<Integer> path = new LinkedList<>(); public ArrayList<ArrayList<Integer>> combine (int n, int k) { getComination(n, k, 1); return res; } private void getComination(int n, int k, int startIndex) { if (path.size() == k) { res.add(new ArrayList(path)); } for (int i = startIndex; i <= n; ++i) { path.add(i); getComination(n, k, i + 1); path.removeLast(); } } }