问题描述: 子集和问题的一个实例为<S,t>.其中,S={x1,x2,....xn}是一个正整数的集合,c是一个正整数。子集和问题判定是否存在S的一个子集S1,使得 。试设计一个解子集和问题的回溯法。
算法设计:对于给定的正整数的集合S={x1,x2,....xn}和正整数c,计算S的一个子集S1,使得 。
数据输入:第一行有2个正整数n和c,n表示S的大小,c是子集和的目标值。接下来的1行中,有n个正整数,表示集合S中的元素。
输入样例:
5 10
2 2 6 5 4
结果输出:将子集和问题的解输出。当问题无解时,输出“No Solution!”
输出样例:
2 2 6
回溯法:DFS+剪枝
AC码:
#include<bits/stdc&