Anagrams are those pair of Strings which have the same set of characters , in any order
For Example :
Mad, Dam
Madam Curie = Radium came
Dog, God
Anagram: Wiki
Problem : Given two input strings s1, s2 , check wether they are anagrams of each other
Solution
Implementation :
 
  
   
   
  
   
   
  
   
  
For Example :
Mad, Dam
Madam Curie = Radium came
Dog, God
Anagram: Wiki
Problem : Given two input strings s1, s2 , check wether they are anagrams of each other
Solution
- Create two int arrays of size 256 , each holding count of the ascii characters present in s1 and s2 respectively
- [ You will need to convert each letter to lower case before adding count]
- Compare count arrays
Implementation :
 public static Boolean  isAnagram(String s1, String s2){
              int count1[] = new int[256];
              int count2[]= new int[256];
              Boolean flag= true;
              for(int i=0;i<s1.length();i++){
                   Character c= s1.charAt(i);
                   count1[Character.toLowerCase(c)]++;
             }
             for(int i=0;i<s2.length();i++){
                   Character c= s2.charAt(i);
                   count2[Character.toLowerCase(c)]++;
             }
             for(int i=0;i<256;i++){
                   if(count1[i]!=count2[i]) flag=false;
             }
      return flag;
 }
 
No comments:
Post a Comment