幼儿园分班

一、题目描述

幼儿园两个班的小朋友排队时混在一起,每位小朋友都有一个编号,且明确标识自己是否与前一位小朋友同班(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));
        }
    }
}
相关推荐
铁蛋AI编程实战11 分钟前
通义千问 3.5 Turbo GGUF 量化版本地部署教程:4G 显存即可运行,数据永不泄露
java·人工智能·python
晚霞的不甘22 分钟前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
马猴烧酒.22 分钟前
【面试八股|JVM虚拟机】JVM虚拟机常考面试题详解
jvm·面试·职场和发展
SunnyDays101124 分钟前
使用 Java 冻结 Excel 行和列:完整指南
java·冻结excel行和列
摇滚侠35 分钟前
在 SpringBoot 项目中,开发工具使用 IDEA,.idea 目录下的文件需要提交吗
java·spring boot·intellij-idea
爱敲代码的TOM40 分钟前
数据结构总结
数据结构
云姜.40 分钟前
java多态
java·开发语言·c++
李堇43 分钟前
android滚动列表VerticalRollingTextView
android·java
CoderCodingNo1 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人1 小时前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程