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