Algo91 算法训练 Anagrams问题
题目如下:
这道题其实就是给你两个单词,判断这两个单词里的每个字母出现的次数是否一样,而且单词最不超过80,你想怎么暴力怎么暴力,但暴力也要有美感
直接上代码,有注释
package algo;
import java.util.Arrays;
import java.util.Scanner;
/**
* @Description: 算法训练 Anagrams问题
* @ClassName: Algo91
* @author: fan.yang
* @date: 2020/07/20 21:07
*/
public class Algo91 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
//不区分大小写哦 直接转成大写或者小写方便点 我这小写
String str1 = scanner.next().toLowerCase();
String str2 = scanner.next().toLowerCase();
//为了循环次数一致 先判断一波
if(str1.length() != str2.length()){
System.out.println("N");
}
//设一个26大小的数组 没错 对应26个字母
int[] array = new int[26];
for(int i = 0;i < str1.length();i++){
//一个专门加加 一个专门减减 最后为0就代表个数一样
array[str1.charAt(i) - 'a']++;
array[str2.charAt(i) - 'a']--;
}
//判断一波是否全为0
System.out.println(Arrays.stream(array).allMatch(e -> e == 0) ? "Y" : "N");
}
}