import java.util.Scanner;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
// 读一个单词(本题只有一个 case)
String s = in.next();
int[] cnt = new int[26];
// 统计每个字母出现次数
for (char c : s.toCharArray()) {
cnt[c - 'a']++;
}
int max = 0;
int min = 1000; // 初始足够大
for (int num : cnt) {
if (num == 0) continue; // 没出现过的字母不算
if (num > max) max = num;
if (num < min) min = num;
}
int t = max - min;
boolean isPrime = true;
// 质数判断
if (t <= 1) {
isPrime = false;
} else {
for (int i = 2; i * i <= t; i++) { // 用 i*i 避免浮点
if (t % i == 0) {
isPrime = false;
break;
}
}
}
if (isPrime) {
System.out.println("Lucky Word");
System.out.println(t);
} else {
System.out.println("No Answer");
System.out.println(0);
}
}
}
知识点:
1.输入字符串
java复制代码
Scanner in = new Scanner(System.in);
// 读一个单词(本题只有一个 case)
String s = in.next();
2.统计每个字母出现次数,找出出现次数最多和最少的字母
java复制代码
int[] cnt = new int[26];
// 统计每个字母出现次数
for (char c : s.toCharArray()) {
cnt[c - 'a']++;
}
int max = 0;
int min = 1000; // 初始足够大
for (int num : cnt) {
if (num == 0) continue; // 没出现过的字母不算
if (num > max) max = num;
if (num < min) min = num;
}
3.质数判断
java复制代码
int t = max - min;
boolean isPrime = true;
// 质数判断
if (t <= 1) {
isPrime = false;
} else {
for (int i = 2; i * i <= t; i++) { // 用 i*i 避免浮点
if (t % i == 0) {
isPrime = false;
break;
}
}
}
二、主持人调度
java复制代码
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param schedule int整型ArrayList<ArrayList<Integer>>
* @return bool布尔型
*/
public boolean hostschedule (ArrayList<ArrayList<Integer>> schedule) {
int n = schedule.size();
int[] start = new int[n];
int[] end = new int[n];
for (int i = 0; i < n; i++) {
start[i] = schedule.get(i).get(0);
end[i] = schedule.get(i).get(1);
}
Arrays.sort(start);
Arrays.sort(end);
for (int i = 0; i < n - 1; i++) {
if (start[i + 1] < end[i]) {
return false;
}
}
return true;
}
}