判断字符串是否包含在某个集合中

算法 给定一个字符串“catanddog”和一个字符串集合Set dic = {“cat”, “ca”, “and”, “dog”},判断dic中是否可以取出一个子集,这个子集可以组成给定字符串。
例如:catanddog在dic中
catandrow则不在当中
catanddogandrow也不在当中

import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;

public class sp {
    static Set<String> set = new HashSet();
    static {
        set.add("cat");
        set.add("and");
        set.add("dogs");
        set.add("ca");
        set.add("cas");
    }

    public static void main(String[] args) {
        String str = "catanddogs";

        System.out.println(contain(str));
    }

    public static boolean contain(String string){
        if (set.contains(string)) {
            return true;
        }
        for (String s : set) {
            String[] split = string.split(s);
            if (split.length == 1) {
                continue;
            }
            boolean result = true;
            for (String str: split) {
                boolean contain = contain(str);
                if (!contain) {
                    result = false;
                    break;
                }
            }
            if (result) {
                return result;
            }
        }
        return false;
    }
}


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值