【华为OD】D卷真题200分:评论转换输出 Java代码实现【思路+代码】

【华为OD】2024年C、D卷真题集:最新的真题集题库 C/C++/Java/python/JavaScript

【华为OD】2024年C、D卷真题集:最新的真题集题库 C/C++/Java/python/JavaScript-CSDN博客

JS、C、python、Java、C++代码实现:

【华为OD】D卷真题200分:评论转换输出 JavaScript代码实现【思路+代码】-CSDN博客

【华为OD】D卷真题200分:评论转换输出 C语言代码实现【思路+代码】-CSDN博客 

【华为OD】D卷真题200分:评论转换输出 python代码实现【思路+代码】-CSDN博客 

【华为OD】D卷真题200分:评论转换输出 Java代码实现【思路+代码】-CSDN博客 

【华为OD】D卷真题200分:评论转换输出 C++代码实现【思路+代码】-CSDN博客 

题目描述:

在一个博客网站上,每篇博客都有评论。每一条评论都是一个非空英文字母字符串。
评论具有树状结构,除了根评论外,每个评论都有一个父评论。
当评论保存时,使用以下格式:

  • 首先是评论的内容;
  • 然后是回复当前评论的数量。
  • 最后是当前评论的所有子评论。(子评论使用相同的格式嵌套存储)

所有元素之间都用单个逗号分隔。
例如,如果评论如下:

第一条评论是"hello,2,ok,0,bye,0",第二条评论是"test,0",第三条评论是"one,1,two,1,a,0"。
所有评论被保存成"hello,2,ok,0,bye,0,test,0,one,1,two,1,a,0"。

对于上述格式的评论,请以另外一种格式打印:
首先打印评论嵌套的最大深度。
然后是打印n行,第i(1<=i<=n)行对应于嵌套级别为i的评论(根评论的嵌套级别为1)。
对于第i行,嵌套级别为i的评论按照它们出现的顺序打印,用空格分隔开。
 

输入描述

一行评论。由英文字母、数字和英文逗号组成。

保证每个评论都是由英文字符组成的非空字符串。

每个评论的数量都是整数(至少由一个数字组成)。

整个字符串的长度不超过106。

给定的评论结构保证是合法的。

输出描述

按照给定的格式打印评论。对于每一级嵌套,评论应该按照输入中的顺序打印。

示例1

输入输出示例仅供调试,后台判题数据一般不包含示例

输入

hello,2,ok,0,bye,0,test,0,one,1,two,1,a,0

输出

3
hello test one
ok bye two
a

说明

如题目描述中图所示,最大嵌套级别为3。嵌套级别为1的评论是"hello test one",嵌套级别为2的评论是"ok bye two",嵌套级别为3的评论为"a"。

示例2

输入输出示例仅供调试,后台判题数据一般不包含示例

输入

A,5,A,0,a,0,A,0,a,0,A,0

输出

2
A
A a A a A

说明

如下图所示,最大嵌套级别为2,嵌套级别为1的评论是"A",嵌套级别为2的评论是"A a A a A"

示例3

输入输出示例仅供调试,后台判题数据一般不包含示例

输入

A,3,B,2,C,0,D,1,E,0,F,1,G,0,H,1,I,1,J,0,K,1,L,0,M,2,N,0,O,1,P,0

输出

4
A K M
B F H L N O
C D G I P
E J

说明

如下图所示。

题目解析 :

        根据题目意思,将结果存到树里面,然后输出对应结果就行

代码实现:

import java.util.*;

public class Main {
    public static void read(List<String> allData, String[] head, int level, HashMap<Integer, StringBuilder> res) {
        if (res.containsKey(level)) {
            res.get(level).append(head[0]).append(" ");
        } else {
            StringBuilder stringB = new StringBuilder();
            stringB.append(head[0]).append(" ");
            res.put(level, stringB);
        }

        for (int i = 0; i < Integer.parseInt(head[1]); i++) {
            String[] p = allData.remove(0).split(",");
            read(allData, p, level + 1, res);
        }
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String input = scanner.nextLine(); 
        String[] ss = input.split(",");

        List<String> allData = new ArrayList<>();
        HashMap<Integer, StringBuilder> res = new HashMap<>();

        for (int i = 0; i < ss.length; i += 2) {
            allData.add(ss[i] + "," + ss[i + 1]);
        }

        while (!allData.isEmpty()) {
            String[] head = allData.remove(0).split(",");
            read(allData, head, 1, res);
        }

        System.out.println(res.size());

        for (int i = 1; i <= res.size(); i++) {
            System.out.println(res.get(i));
        }
    }
}

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五木大大

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值