打印字符串所有子序列(暴力递归到动态规划)

package DataStructure;

import java.util.ArrayList;
import java.util.List;

public class PrintAllSubsequence {
    public static List<String> subs(String s){
        char[] str = s.toCharArray();
        String path = "";
        List<String> ans = new ArrayList<>();
        process1(str , 0 , ans , path);
        return ans;
    }
    //str 固定不变
    //index 此时来到的位置 要或者不要
    //如果index到达str的终止位置,就把沿途路径形成的答案 放入ans中
    //之前做出的选择 就是path
    public static  void process1(char[] str , int index , List<String> ans , String path  ) {
        if (index == str.length) {
            ans.add(path);
            return;
        }
        String no = path;//之前的path继续往下传,不包含当前字符
        process1(str, index + 1, ans, no);
        String yes = path + String.valueOf(str[index]);//加上当前位置字符
        process1(str, index + 1, ans, yes);
    }

    
}

子序列:不能逆序,子部分。

思想:深度优先遍历。

如果想要不重复子序列 用hashset收集即可。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值