题解 | #放苹果# 很笨但是很直观的递归方法
放苹果
https://www.nowcoder.com/practice/bfd8234bb5e84be0b493656e390bdebf
//解释看代码 import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.Scanner; import java.util.stream.Collectors; public class Main { static List<List<Integer>> allList; private static void process(int appleNum, int plateNum, int allocated, List<Integer> list) { //还剩一个盘子没放,而且还有苹果那就全放在这个盘子里 if (list.size() == plateNum - 1) { list.add(appleNum - allocated); //深拷贝,这样对item排序不会影响list,这种以后会经常用的 List<Integer> item = new ArrayList<>(list); item.sort(Comparator.comparingInt(i->i)); allList.add(item); list.remove(list.size() - 1); return; } //每个盘子循环数量 for (int i = 0; i <= appleNum - allocated; i++) { list.add(i); process(appleNum, plateNum, allocated + i, list); list.remove(list.size() - 1); } } public static void main(String[] args) { Scanner in = new Scanner(System.in); while (in.hasNextInt()) { int appleNum = in.nextInt(); int plateNum = in.nextInt(); allList=new ArrayList<>(); process(appleNum, plateNum, 0, new ArrayList<>()); //去重 System.out.println(allList.stream().distinct().collect( Collectors.toList()).size()); } } }