码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode[87]Scramble String

时间:2015-02-09 15:31:37      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:

Given a string s1, we may represent it as a binary tree by partitioning it to two non-empty substrings recursively.

Below is one possible representation of s1 = "great":

    great
   /      gr    eat
 / \    /  g   r  e   at
           /           a   t

To scramble the string, we may choose any non-leaf node and swap its two children.

For example, if we choose the node "gr" and swap its two children, it produces a scrambled string "rgeat".

    rgeat
   /      rg    eat
 / \    /  r   g  e   at
           /           a   t

We say that "rgeat" is a scrambled string of "great".

Similarly, if we continue to swap the children of nodes "eat" and "at", it produces a scrambled string "rgtae".

    rgtae
   /      rg    tae
 / \    /  r   g  ta  e
       /       t   a

We say that "rgtae" is a scrambled string of "great".

Given two strings s1 and s2 of the same length, determine if s2 is a scrambled string of s1.

class Solution {
public:
bool isScramble(string s1, string s2) {
        if(s1==s2)return true;
        if(s1.length()!=s2.length())return false;
        int length=s1.size();
        int a[26]={0};
        for(int i=0;i< length;i++)
        {
            a[s1[i]-a]++;
            a[s2[i]-a]--;
        }
        for(int i=0;i<26;i++)
        {
            if(a[i]!=0)return false;
        }
        bool f[length][length][length];  
        memset(f, false, sizeof(bool) * length * length * length);  
//        vector<vector<vector<bool>>> f( length,vector<vector<bool>> ( length,vector<bool> ( length, false)));
        for (int k=1;k<= length;k++)
        {
            for (int i=0;i<= length-k;i++)
            {
                for (int j=0;j<= length-k;j++)
                {
                    if (k==1)
                    {
                        f[i][j][k]=(s1[i]==s2[j]);
                    } 
                    else
                    {
                        for (int kk=1;kk<k;kk++)
                        {
                            if ((f[i][j][kk]&&f[i+kk][j+kk][k-kk])||(f[i+kk][j][k-kk]&&f[i][j+k-kk][kk]))
                            {
                                f[i][j][k]=true;
                                break;
                            }
                        }
                    }
                }
            }
        }
        return f[0][0][length];
    }
/*
bool isScramble(string s1, string s2) {  
        // Start typing your C/C++ solution below  
        // DO NOT write int main() function  
        if (s1.length() != s2.length()) {  
            return false;  
        }  
        int length = s1.length();  
        bool f[length][length][length];  
        memset(f, false, sizeof(bool) * length * length * length);  
          
        for (int k = 1; k <= length; k++) {  
            for (int i = 0; i <= length - k; i++) {  
                for (int j = 0; j <= length - k; j++) {  
                    if (k == 1) {  
                        f[i][j][k] = s1[i] == s2[j];  
                    }  
                    else {  
                        for (int l = 1; l < k; l++) {  
                            if ((f[i][j][l] && f[i + l][j + l][k - l]) || (f[i][j + k - l][l] && f[i + l][j][k - l])) {  
                                f[i][j][k] = true;  
                                break;  
                            }                              
                        }  
                    }  
                }  
            }              
        }  
                  
        return f[0][0][length];  
    } 
bool isScramble(string s1, string s2) 
{
    if(s1==s2)return true;
    if(s1.length()!=s2.length())return false;
    int len1=s1.size(), len2=s2.size();
    int a[26]={0};
    for(int i=0;i<len1;i++)
    {
        a[s1[i]-‘a‘]++;
        a[s2[i]-‘a‘]--;
    }
    for(int i=0;i<26;i++)
    {
        if(a[i]!=0)return false;
    }
    for(int i=1;i<len1;i++)
    {
        bool res1=isScramble(s1.substr(0,i),s2.substr(0,i))&&isScramble(s1.substr(i),s2.substr(i));
        bool res2=isScramble(s1.substr(0,i),s2.substr(len2-i,i))&&isScramble(s1.substr(i),s2.substr(0,len2-i));
        bool res=res1||res2;
        if(res) return res;
    }
    return false;
}
*/
};

 

leetcode[87]Scramble String

标签:

原文地址:http://www.cnblogs.com/Vae98Scilence/p/4281404.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!