幼儿园分班

一、题目描述

幼儿园两个班的小朋友排队时混在一起,每位小朋友都有一个编号,且明确标识自己是否与前一位小朋友同班(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));
        }
    }
}
相关推荐
夏鹏今天学习了吗28 分钟前
【LeetCode热题100(82/100)】单词拆分
算法·leetcode·职场和发展
曹轲恒32 分钟前
Java中断
java·开发语言
xxxmine43 分钟前
Java并发wait(timeout)
java
冰冰菜的扣jio1 小时前
Redis缓存问题——一致性问题、事务、持久化
java·spring·mybatis
施棠海1 小时前
监听与回调的三个demo
java·开发语言
mit6.8241 小时前
mysql exe
算法
2501_901147831 小时前
动态规划在整除子集问题中的应用与高性能实现分析
算法·职场和发展·动态规划
全栈开发圈2 小时前
新书速览|鸿蒙之光HarmonyOS 6应用开发入门
华为·harmonyos
中草药z2 小时前
【嵌入模型】概念、应用与两大 AI 开源社区(Hugging Face / 魔塔)
人工智能·算法·机器学习·数据集·向量·嵌入模型
毕设源码-钟学长2 小时前
【开题答辩全过程】以 家政服务平台为例,包含答辩的问题和答案
java