幼儿园分班

一、题目描述

幼儿园两个班的小朋友排队时混在一起,每位小朋友都有一个编号,且明确标识自己是否与前一位小朋友同班(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));
        }
    }
}
相关推荐
醒过来摸鱼2 小时前
《线性空间》专栏写作计划(目录)
算法
再来一根辣条2 小时前
Stream是怎么运行的?
java
黄俊懿2 小时前
【深入理解SpringCloud微服务】Gateway源码解析
java·后端·spring·spring cloud·微服务·gateway·架构师
Yupureki2 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-二分算法
c语言·开发语言·数据结构·c++·算法·visual studio
悟能不能悟2 小时前
java list.addAll介绍
java·windows·list
Alsn862 小时前
30.登录用户名密码 RSA 加密传输-后端为java
java·开发语言
qq_463408422 小时前
React Native跨平台技术在开源鸿蒙中使用WebView来加载鸿蒙应用的网页版或通过一个WebView桥接本地代码与鸿蒙应用
javascript·算法·react native·react.js·开源·list·harmonyos
Jul1en_2 小时前
【算法】位运算
算法
路人与大师2 小时前
PaddleOCR-VL 华为昇腾 910A NPU 适配详细报告
华为