1、问题描述
题目描述
某财务部门结账时发现总金额不对头。很可能是从明细上漏掉了某 1 笔或几笔。如果已知明细账目清单,能通过编程找到漏掉的是哪 1 笔或几笔吗?
如果有多种可能,则输出所有可能的情况。
输入描述
用户输入的第一行是:有错的总金额。
接下来是一个整数 nn,表示下面将要输入的明细账目的条数。
再接下来是 nn 行整数,分别表示每笔账目的金额。
为了方便,不妨假设所有的金额都是整数;每笔金额不超过 1000,金额的明细条数不超过 100。
输出描述
所有可能漏掉的金额组合。每个情况 1 行。金额按照从小到大排列,中间用空格分开。
输入输出样例
示例
输入
6
5
3
2
4
3
1
输出
1 2 4
1 3 3
3 4
2、代码实现
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;
public class 金额差错 {
static ArrayList<Integer> list = new ArrayList<>();
static int n;
static int[] items;
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int error = scanner.nextInt();
n = scanner.nextInt();
items = new int[n];
int sum = 0;
for(int i = 0;i < n;i++){
items[i] = scanner.nextInt();
sum += items[i];
}
Arrays.sort(items);
int target = sum - error;
dfs(target,0);
}
public static void dfs(int target,int k){
if(target < 0){
return;
}
if(target == 0){
for(int i : list){
System.out.print(i + " ");
}
System.out.println();
return;
}
for(int i = k;i < n;i++){
if(i > k && items[i] == items[i - 1]){
continue;
}
list.add(items[i]);
//深搜
dfs(target - items[i],i + 1);
//回溯
list.remove(list.size() - 1);
}
}
}