笔试强训练习

一、笨小猴

题目:

java 复制代码
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;
    }
}

1.ArrayList<ArrayList<Integer>>是动态二维数组,ArrayList 嵌套集合

2.拿到所有活动起止时间

start[] 存所有活动开始时间end[] 存所有活动结束时间

java 复制代码
int[] start = new int[n];
int[] end = new int[n];

3.ArrayList 集合遍历

java 复制代码
 for (int i = 0; i < n; i++) {
            start[i] = schedule.get(i).get(0);
            end[i] = schedule.get(i).get(1);
 }
        

4.数组排序 Arrays.sort () --贪心

java 复制代码
 Arrays.sort(start);  // 给开始时间排序
 Arrays.sort(end);    // 给结束时间排序

5.区间重叠判断

java 复制代码
for (int i = 0; i < n - 1; i++) {
    if (start[i + 1] < end[i]) {
         return false; // 有重叠 → 不行
    }
}
相关推荐
小雨下雨的雨22 分钟前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.3 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
明夜之约3 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee3 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Jinkxs3 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
辣机小司3 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
海兰3 小时前
【水浒传:第二篇】AI江湖 —项目详细设计指南(一)
jvm·人工智能·游戏
一条小锦吕*3 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
CryptoPP4 小时前
快速对接东京证券交易所API数据:实战指南与代码示例
开发语言·人工智能·windows·python·信息可视化·区块链
ZC跨境爬虫4 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript