我有以下的代码,需要2个字符串作为输入,并返回布尔他们是否是字谜:结束语switch语句在一个整洁的循环在Java中
import java.util.ArrayList;
import java.util.Scanner;
public class AnagramChecker {
public static void main(String[] args) {
Scanner sc = new Scanner (System.in);
System.out.print ("Enter string 1: ");
String str1 = sc.nextLine();
System.out.print ("Enter string 2: ");
String str2 = sc.nextLine();
boolean check = isAnagram (str1, str2);
System.out.println ("Anagram check for '" + str1 + "' and '" + str2 + "': " + check);
sc.close();
}
public static boolean isAnagram (String s1, String s2) {
if(s1.length() != s2.length())
return false;
s1 = s1.toLowerCase();
s2 = s2.toLowerCase();
ArrayList<String> myList = new ArrayList<String>();
for(int i = 0; i < s2.length() ; i++){
myList.add(String.valueOf(s2.charAt(i)));
}
for(int i = 0; i < s1.length();i++){
for(int j = 0; j < myList.size(); j++){
if(myList.get(j).equals(String.valueOf(s1.charAt(i)))){
myList.remove(j);
j = 0;
break;
}
}
}
return myList.isEmpty();
}
}
这是比较有限的,虽然,我试图将它扩大到以下情况下工作: - 不同的情况下,即eager == AGREE
- 一个字与空格,即eager == a g ree
- 不同量的空白即" eager" == agree
是否有这个整合到一个非常干净的方式已经写了上面的代码,没有太多的痛苦和重写。任何帮助非常感谢。谢谢。
您想要以不同方式处理它们,还是只删除每个空格并将字符串转换为小写? – Tom
您已经处理了混合大小写。你可以删除所有的空格。 –
能够比较字符串,无论他们在多少空间和位置(前面/中间/后面的字符串)是我最初想到的 – cslecturect