Chinaunix首页 | 论坛 | 博客
  • 博客访问: 272092
  • 博文数量: 170
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1709
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-06 18:01
文章分类

全部博文(170)

文章存档

2016年(11)

2015年(130)

2014年(29)

分类: Java

2015-09-19 10:50:28

//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 .
public class ScrambleString {


public static void main(String[] args) {
// TODO Auto-generated method stub


}
public  boolean isScramble(String s1, String s2) {
if(s1.equals(s2)){
return true;
}
if(s1.length()!=s2.length()){
return false;
}
  int[] charset =new int[26];
       for(int i = 0 ; i < s1.length() ; ++i)
         charset[s1.charAt(i)-'a']++;
       for(int i = 0 ; i < s2.length() ; ++i)
         charset[s2.charAt(i)-'a']--;
       for(int i = 0 ; i < 26 ; ++i)
         if(charset[i] != 0) return false;
       
      boolean result=false;
      for(int i = 1 ; i < s1.length() ; ++i){
      result = isScramble(s1.substring(0,i) , s2.substring(0,i)) && isScramble(s1.substring(i) , s2.substring(i));
      if(result) return true;
           result = isScramble(s1.substring(0,i) , s2.substring(s1.length()-i,s1.length())) && isScramble(s1.substring(i) , s2.substring(0 , s1.length()-i));
           if(result) return true;
      }
      return false;
}
}

阅读(312) | 评论(0) | 转发(0) |
0

上一篇:PartitionList

下一篇:GrayCode

给主人留下些什么吧!~~