Мне нужно найти способ проверить две строки, если они анаграммы. Если они есть, метод должен возвращать true и false в противном случае. Так как я не мог придумать правильный способ сделать это самостоятельно, я нашел еще один фрагмент кода Родни Шагулиана (Github: github.com/RodneyShag, HackerRank: hackerrank.com/RodneyShag), который должен работать:
import java.io.*;
import java.util.*;
public class Solution {
static boolean isAnagram(String a, String b) {
if (a == null || b == null || a.length() != b.length()) {
return false;
}
a = a.toLowerCase();
b = b.toLowerCase();
HashMap<Character, Integer> map = new HashMap<>();
/* Fill HashMap with 1st String */
for (int i = 0; i < a.length(); i++) {
char ch = a.charAt(i);
map.merge(ch, 1, Integer::sum);
}
/* Compare 2nd String to 1st String's HashMap */
for (int i = 0; i < b.length(); i++) {
char ch = b.charAt(i);
if (map.containsKey(ch) && map.get(ch) > 0) {
map.put(ch, map.get(ch) - 1);
} else {
return false;
}
}
return true;
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
String a = scan.next();
String b = scan.next();
scan.close();
boolean ret = isAnagram(a, b);
System.out.println( (ret) ? "Anagrams" : "Not Anagrams" );
}
}
Я просто скопировал и вставил его в собственную IDE, но в строке 18 получил три ошибки компиляции:
map.merge(ch, 1, Integer::sum);
Сказать, что
')' expected,
illegal start of expression,
error: ';' expected.
Что я не понимаю, так как не вижу скобок или чего-то пропущенного. Код также явно работал для автора.
Может кто-нибудь помочь мне увидеть проблему?
Кроме того, есть ли способ сравнить две строки, чтобы увидеть, являются ли они анаграммами без использования hashmap? Возможно, с помощью метода string to char [] и для циклов? (Это был оригинальный способ, которым я придумал, я совсем не знаком с хэш-картами.)