幼儿园分班

一、题目描述

幼儿园两个班的小朋友排队时混在一起,每位小朋友都有一个编号,且明确标识自己是否与前一位小朋友同班(Y 表示同班,N 表示不同班)。

需根据该标识将小朋友划分到两个班级,并满足以下输出规则:

  1. 每个班级的小朋友编号按升序排列;
  2. 第一个编号更小的班级排在第一行,第二个班级排在第二行;
  3. 若仅一个班级,第二行为空行;
  4. 输入不符合要求时直接输出 ERROR

二、输入输出描述

输入描述

输入为空格分隔的字符串,每个字符串格式为 编号/标志(如 6/N 2/Y 3/N 4/Y).

备注:

  • 小朋友总数 ≤ 999;
  • 编号范围:1 ≤ 编号 ≤ 999;
  • 标志仅为 YN
  • 第一个小朋友无 "前一位",其标志无实际意义(需做合法性校验)。

输出描述

  • 第一行:第一个编号更小的班级的升序编号(空格分隔);
  • 第二行:第二个班级的升序编号(空格分隔),若无则为空行;
  • 非法输入输出 ERROR

三、示例

|----|---------------------------------------------------------------------------------|
| 输入 | 1/N 2/Y 3/N 4/Y |
| 输出 | 1 2 3 4 |
| 说明 | 2的同班标记为Y,因此和1同班。 3的同班标记为N,因此和1、2不同班。 4的同班标记为Y,因此和3同班。 所以1、2同班,3、4同班,输出为 1 2 3 4 |

|----|---------------------------------------------------------------------------------|
| 输入 | 1/N 2/Y 3/N 4/Y 5/Y |
| 输出 | 1 2 3 4 5 |
| 说明 | 2的同班标记为Y,因此和1同班。 3的同班标记为N,因此和1、2不同班。 4的同班标记为Y,因此和3同班。 所以1、2同班,3、4同班,输出为 1 2 3 4 |

四、解题思路

  1. 核心思想

通过 "临时列表控制优先班级顺序" 的方式,动态调整编号的班级分配规则:标记Y保持分配顺序,标记N反转分配顺序,最终对两个班级的编号按数字升序排序输出 ------ 核心是 "用列表反转模拟班级分配顺序切换,简化条件判断逻辑"。

  1. 问题本质分析
  • 表层问题:根据标记动态分配编号到两个班级,最终排序输出;
  • 深层问题:
    1. 动态分配规则的实现:标记N本质是 "交换下一个编号的分配目标班级",用列表反转可高效实现这一逻辑,无需频繁判断 "当前该分配到哪个班";
    2. 编号排序:需将字符串形式的编号按数字大小升序排列(而非字符串字典序);
    3. 边界处理:空班级无需输出,避免无效打印。
  1. 核心逻辑
  • 初始分配:第一个编号固定入 A 班,初始化临时列表temp为 [A,B](A 为优先班级);
  • 动态切换:标记N时反转temp(交换优先班级),标记Y时保持;
  • 统一分配:无论标记如何,编号始终加入temp.get(0)(当前优先班级),简化分配逻辑;
  • 排序输出:按数字升序排序班级编号,非空则输出。
  1. 步骤拆解

  2. 输入初始化

    • 分割输入为 "编号 / 标记" 数组,提取第一个编号加入 A 班;
    • 初始化临时列表temp,按 [A,B] 顺序存储两个班级。
  3. 动态分配编号

    • 遍历后续每个 "编号 / 标记":
      1. 标记为N时,反转temp列表(切换优先班级);
      2. 将编号加入temp.get(0)(当前优先班级)。
  4. 排序处理

    • 对 A、B 班的编号,按 "字符串转整数后升序" 的规则排序。
  5. 结果输出

    • 非空班级按空格拼接编号并输出,空班级跳过。

五、代码实现

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String[] nums = scanner.nextLine().split(" ");

        String[] start = nums[0].split("/");
        List<String> class_A = new ArrayList<>();
        class_A.add(start[0]);
        List<String> class_B = new ArrayList<>();

        List<List<String>> temp = new ArrayList<>();
        temp.add(class_A);
        temp.add(class_B);

        for (int i = 1; i < nums.length; i++) {
            String[] current = nums[i].split("/");
            String id_ = current[0];
            String f = current[1];

            if (f.equals("Y")) {
                temp = temp;
            } else {
                Collections.reverse(temp);
            }

            temp.get(0).add(id_);
        }

        if (!class_A.isEmpty()) {
            Collections.sort(class_A, (a, b) -> Integer.parseInt(a) - Integer.parseInt(b));
            System.out.println(String.join(" ", class_A));
        }

        if (!class_B.isEmpty()) {
            Collections.sort(class_B, (a, b) -> Integer.parseInt(a) - Integer.parseInt(b));
            System.out.println(String.join(" ", class_B));
        }
    }
}
相关推荐
松仔log1 小时前
JetPack——Paging3+Room
android·java·zoom
Lei活在当下6 小时前
先用起来,再理解,关于协程Coroutine应该知道的事
android·java·jvm
Java爱好狂.7 小时前
Java程序员体系化学习路线(2026最新版)
java·后端·java面试·java架构师·java程序员·java八股文·java学习路线
程序猿追7 小时前
在 HarmonyOS 模拟器上种出斐波那契螺旋线
大数据·人工智能·microsoft·华为·harmonyos
tongluowan0077 小时前
以ReentrantLock为例解释AQS的工作流程
java·模板方法模式·aqs·reentrantlock
Raink老师7 小时前
【AI面试临阵磨枪-62】设计基于 RAG 的内部知识库问答平台(多租户、权限、文件上传、实时更新)
人工智能·面试·职场和发展
身如柳絮随风扬8 小时前
Java 项目打包与部署完全指南:JAR vs WAR,从构建到运行
java·firefox·jar
云烟成雨TD8 小时前
Spring AI Alibaba 1.x 系列【62】时光旅行(Time-Travel)
java·人工智能·spring
lqj_本人8 小时前
鸿蒙electron框架PC适配:ExifCleaner 适配鸿蒙全过程:一次从“能启动”到“能处理文件”的完整复盘
华为·electron·harmonyos
smj2302_796826529 小时前
解决leetcode第3943题递增后的数对数量
数据结构·python·算法·leetcode