题目描述

给定两个字符串,请编写程序,确定其中一个字符串的字符重新排列后,能否变成另一个字符串。这里规定大小写为不同字符,且考虑字符串重点空格。

给定一个string stringA和一个string stringB,请返回一个bool,代表两串是否重新排列后可相同。保证两串的长度都小于等于5000。

分析:两个字串是否同构,首先先判断是否长度一样,长度相同才有可能同构,其次,同构的花就是每个字符出现的次数和另一个字符串次数一样。可以遍历两个字符串,用两个标记记录每个字符出现的次数。最后总数相同的话。即为同构

JAVA:

import java.util.*;
public class Same {
    public boolean checkSam(String stringA, String stringB) {
        // write code here
        if(stringA.length()!=stringB.length())
            return false;
        int count1=0;
        int count2=0;
        for(int i=0;i<stringA.length();i++)
            for(int j=0;j<stringB.length();j++)
            {
                if(stringA.charAt(i)==stringA.charAt(j))
                    count1++;
                if(stringA.charAt(i)==stringB.charAt(j))
                    count2++;
                
            }
        if(count1==count2)
            return true;
        else
            return false;
        
        
    }
}
        
        
    }
}

增添一种思路:总共有256个字符,定义数组记录两个字符串中每个字符出现的次数,最后遍历所有的字符如果每个字符出现的次数都相同的话,即是同构的

java:

import java.util.*;
public class Same {
    public boolean checkSam(String stringA, String stringB) {
        // write code here
        int[]a=new int[256];
        int[]b=new int[256];
        if(stringA.length()!=stringB.length())
            return false;
        else{
            for(int i=0;i<stringA.length();i++)
                a[stringA.charAt(i)]++;
            for(int i=0;i<stringB.length();i++)
                b[stringB.charAt(i)]++;
            for(int i=0;i<256;i++)
                if(a[i]!=b[i])
                    return false;
            return true;
        }
    }
}