LeetCode: Scramble String

思路:这个参考了网上的思路,设置分割点递归求解,假设分割点在i, 则s1(0,...,n) 如果是s2(0,...,n) 的Scramble String,则有两种情况:

1. s1(0...i) 与 s2(0...i) 是Scramble String,且s1(i+1,...,n) 与 s2(i+1,...n)是Scramble String;

或者

2. s1(0...i) 与 s2(i+1,...n) 是Scramble String,且s1(i+1,...,n) 与 s2(0...i)是Scramble String;

依次递归求解即可。

注意:

可以实现统计两个字符串的每个字母个数是否相同,可以加快速度,否则会TLE,当然还可以实现判断字符串长度是否相同。

code:

class Solution {
public:
    bool isSameCount(string s1,string s2){
        if(s1.length() != s2.length()) return false;
        int count[26] = {0};
        for(int i = 0;i < s1.length();i++)
            count[s1[i] - 'a']++;
        for(int i = 0;i < s2.length();i++){
            count[s2[i] - 'a']--;
            if(count[s2[i] - 'a'] < 0) return false; 
        }
        return true;
    }
    bool isScramble(string s1, string s2) {
        if(s1 == s2) return true;
        if(s1.size() != s2.size()) return false;
        bool samecount = isSameCount(s1,s2);
        if(!samecount) return false;
        bool result = false;
        for(int i = 1 ; i < s1.size() ; ++i) {
            result = isScramble(s1.substr(0,i) , s2.substr(0,i)) && isScramble(s1.substr(i) , s2.substr(i));
            if(result) return true;
            result = isScramble(s1.substr(0,i) , s2.substr(s1.size()-i,i)) && isScramble(s1.substr(i) , s2.substr(0 , s1.size()-i));
            if(result) return true;
        }
        return false;
    }
};


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值