回溯法:子集和数

文章介绍了一个寻找正数序列子集和等于特定数值的问题。给定一个不包含重复数字的正数序列和目标和M,要求找出所有和为M的子集。通过深度优先搜索(DFS)的递归方法,遍历序列并选择或不选择每个元素,以找到满足条件的子集。文章提供了两种不同的DFS实现策略,一种是遇到满足条件的子集就立即输出,另一种是遍历完整个序列后再输出满足条件的子集。
摘要由CSDN通过智能技术生成

子集和数例题

已知n个不重复的正数:wi​, 1<=i<=n, 和M,要求找出wi​的所有子集使得子集内元素之和等于M。

题目分析

既然该序列不包含重复数字,那么子集的个数肯定是2n(因为求子集时对每个元素都有选或者不选两个操作),算法的时间复杂度就是O(2n)。

编程要求

根据提示,在右侧编辑器补充代码,完成子集和数。

测试说明

平台会对你编写的代码进行测试:

输入 n,m;n为数的个数。m为和数的大小。 输出 选取方案,具体哪些数。

测试输入:

 
  1. 4 5
  2. 1 3 2 4

预期输出:

 
  1. 1 3
  2. 2 4

测试输入:

 
  1. 10 7
  2. 1 3 6 2 5 4 -1 9 7 10

预期输出:

 
  1. 7
  2. 2 5
  3. 6 2 -1
  4. 3 4</
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值