评论转换输出 - 华为OD统一考试

OD统一考试

分值: 200分

题解: Java / Python / C++

alt

题目描述

在一个博客网站上,每篇博客都有评论。每一条评论都是一个非空英文字母字符串。

评论具有树状结构,除了根评论外,每个评论都有一个父评论。当评论保存时,使用以下格式:

首先是评论的内容;

然后是回复当前评论的数量。

最后是当前评论的所有子评论。(子评论使用相同的格式嵌套存储)

所有元素之间都用单个逗号分隔。

例如,如果评论如下:

image-20240112161004444

第一条评论是"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行,嵌套级别为的评论按照它们出现的顺序打印,用空格分隔开。

输入描述

一行评论。由英文字母、数字和英文逗号组成。保证每个评论都是由英文字符组成的非空字符串。每个评论的数量都是整数(至少由一个数字组成)。整个字符串的长度不超过10^6。给定的评论结构保证是合法的。

输出描述

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

示例1

输入:
hello,2,ok,0,bye,0,test,0,one,1,two,1,a,0输出:
3
hello test one
ok bye two
a

示例2

输入:
A,5,A,0,a,0,A,0,a,0,A,0输出:
2
A
A a A a A

image-20240112161355044

示例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

image-20240112162348095

题解

题目类型:树状结构的遍历,可以使用深度优先搜索(DFS)。

解题思路

  1. 定义一个评论类,包含评论内容、回复数量以及回复的评论列表。
  2. 使用递归解析评论数据,构建评论树。
  3. 使用深度优先搜索(DFS)遍历评论树,按照嵌套级别将评论内容存储到对应的列表中。
  4. 输出最大嵌套深度和每个嵌套级别的评论内容。

代码描述

  1. 定义Comment类,包含评论内容、回复数量、回复的评论列表。
  2. 解析评论数据的函数parseComment
  3. 深度优先搜索的函数dfs,将评论内容按照嵌套级别存储到result列表中。
  4. 主函数中读取输入,构建评论树,进行深度优先搜索,并输出结果。

时间复杂度:假设评论数为N,则构建评论树和深度优先搜索的时间复杂度为O(N)。

空间复杂度:需要存储评论树和结果列表,空间复杂度为O(N)。

Java

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;class Comment {/*** 评论类*/String data;int replyCnt;List<Comment> replys;public Comment(String data, int replyCnt) {this.data = data;this.replyCnt = replyCnt;this.replys = new ArrayList<>();}
}/*** @author code5bug*/
public class Main {static int idx;static String[] ds;static List<List<String>> result;/*** 解析评论数据** @return*/public static Comment parseComment() {String data = ds[idx];int replyCnt = Integer.parseInt(ds[idx + 1]);idx += 2;Comment comment = new Comment(data, replyCnt);for (int i = 0; i < replyCnt; i++) {comment.replys.add(parseComment());}return comment;}/*** 遍历评论内容,并将评论的内容放到result的对应的嵌套级别中** @param comment* @param level*/public static void dfs(Comment comment, int level) {if (result.size() <= level) {result.add(new ArrayList<>());}result.get(level).add(comment.data);for (Comment rep : comment.replys) {dfs(rep, level + 1);}}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);ds = scanner.nextLine().split(",");idx = 0;int N = ds.length;List<Comment> comments = new ArrayList<>();while (idx < N) {comments.add(parseComment());}result = new ArrayList<>();for (Comment comment : comments) {dfs(comment, 0);}System.out.println(result.size());for (List<String> cs : result) {System.out.println(String.join(" ", cs));}}
}

Python

class Comment:"""评论类"""def __init__(self, data, reply_cnt) -> None:self.data = dataself.reply_cnt = reply_cntself.replys = []def parse_comment() -> Comment:"""解析评论数据"""global idx, dsdata, reply_cnt = ds[idx], int(ds[idx + 1])idx += 2comment = Comment(data, reply_cnt)for _ in range(reply_cnt):  # 评论的回复comment.replys.append(parse_comment())return commentdef dfs(comment: Comment, level: int):"""遍历评论内容,并将评论的内容放到result的对应的嵌套级别中"""global resultif len(result) <= level:result.append([])result[level].append(comment.data)for rep in comment.replys:dfs(rep, level + 1)ds = input().split(",")
idx, N = 0, len(ds)
comments = []
while idx < N:comments.append(parse_comment())result = []
for comment in comments:dfs(comment, 0)print(len(result))
for cs in result:print(" ".join(cs))

C++

#include <iostream>
#include <vector>
#include <sstream>using namespace std;// 评论类
class Comment {
public:string data;int replyCnt;vector<Comment> replys;Comment(const string& data, int replyCnt) : data(data), replyCnt(replyCnt) {}
};int idx;
vector<string> ds;
vector<vector<string>> result;/*** 解析评论数据** @return*/
Comment parseComment() {string data = ds[idx];int replyCnt = stoi(ds[idx + 1]);idx += 2;Comment comment(data, replyCnt);for (int i = 0; i < replyCnt; i++) {comment.replys.push_back(parseComment());}return comment;
}/*** 遍历评论内容,并将评论的内容放到result的对应的嵌套级别中** @param comment* @param level*/
void dfs(const Comment& comment, int level) {if (result.size() <= static_cast<size_t>(level)) {result.emplace_back();}result[level].push_back(comment.data);for (const Comment& rep : comment.replys) {dfs(rep, level + 1);}
}int main() {string input;getline(cin, input);istringstream iss(input);string token;while (getline(iss, token, ',')) {ds.push_back(token);}idx = 0;int N = ds.size();vector<Comment> comments;while (idx < N) {comments.push_back(parseComment());}result.clear();for (const Comment& comment : comments) {dfs(comment, 0);}cout << result.size() << endl;for (const auto& cs : result) {cout << cs[0];for (size_t i = 1; i < cs.size(); ++i) {cout << " " << cs[i];}cout << endl;}return 0;
}

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/616967.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

环信服务端下载消息文件---菜鸟教程

前言 在服务端&#xff0c;下载消息文件是一个重要的功能。它允许您从服务器端获取并保存聊天消息、文件等数据&#xff0c;以便在本地进行进一步的处理和分析。本指南将指导您完成环信服务端下载消息文件的步骤。 环信服务端下载消息文件是指在环信服务端上&#xff0c;通过调…

重学Java 1.学习路线及相关概述

别灰心&#xff0c;好运会降临 ——24.1.11 Ss.1 学习框架图 Ss.2 硬件和软件 硬件是看得见、摸得着的物理部件或设备 软件是以程序和文档的形式存在 硬件和软件是相辅相成的&#xff0c;谁也离不开谁 Ss.3 计算机语言 计算机编程语言&#xff0c;就是人们对计算机下达的命令&a…

Linux集锦大全【持续更新】

文章目录 Linux集锦大全【持续更新】Linux最常用的几个归档和压缩命令解压方法之一 tar语法压缩文件查看压缩文件的内容解压文件 解压方法之一 zip语法参数参考实例仅保存文件名 解压命令之一 unzip基本命令指定目录解压不解压某些文件 解压命令之一 gzip Linux最危险的几个命令…

OpenGL学习笔记-Blending

混合方程中&#xff0c;Csource是片段着色器输出的颜色向量&#xff08;the color output of the fragment shader&#xff09;&#xff0c;其权重为Fsource。Cdestination是当前存储在color buffer中的颜色向量&#xff08;the color vector that is currently stored in the …

NAND Separate Command Address (SCA) 接口命令解读

CA output packet和CA input packet是Separate Command Address (SCA) NAND接口协议中用于命令和地址传输的关键数据结构。 CA Input Packet: 在SCA接口中&#xff0c;输入到NAND器件的命令和地址信息被组织成并行至串行转换的CA&#xff08;Command and Address&#xff09;输…

List列表操作中的坑

使用 Arrays.asList 把数据转换为 List 的三个坑 在如下代码中&#xff0c;我们初始化三个数字的 int[]数组&#xff0c;然后使用 Arrays.asList 把数组转换为 List&#xff1a; int[] arr {1, 2, 3}; List list Arrays.asList(arr); log.info("list:{} size:{} class…

服务器应用相关代码

1&#xff1a;建立基本网络服务器 我们的ESP866-NodeMCU虽然也能实现网络服务器的一些功能&#xff0c;但是毕竟它的运算能力是无法与那些昂贵的服务器电脑相媲美的&#xff0c;因此ESP8266-NodeMCU只能实现一些基本的网络服务功能。网络服务是一个很宽泛的概念&#xff0c;我…

HCIA的交换机(单臂路由)

实现单臂路由的IP自动分配 实验素材&#xff1a; 实现思路&#xff1a; 交换机&#xff1a;创建VLAN10&#xff0c;VLAN20&#xff0c;将0/0/1&#xff0c;2划入相应VLAN&#xff0c;接口使用access模式&#xff0c; 要实现两个交换机之间的通信&#xff0c;须在0/0/3口使用t…

MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点

MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点 MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点 整步驱动模式&#xff1a;在整步驱动模式中&#xff0c;步进电机控制器按照脉冲方向指令对两相步进电机的两个线圈进行循环激磁。每个脉冲会使电机移动一个…

知乎x-zse-96算法分析

声明 本文以教学为基准、本文提供的可操作性不得用于任何商业用途和违法违规场景。 本人对任何原因在使用本人中提供的代码和策略时可能对用户自己或他人造成的任何形式的损失和伤害不承担责任。 如有侵权,请联系我进行删除。 这里只是我分析过程,以及一些重要点的记录,没有…

YOLOv5改进系列(25)——添加LSKNet注意力机制(大选择性卷积核的领域首次探索)

【YOLOv5改进系列】前期回顾: YOLOv5改进系列(0)——重要性能指标与训练结果评价及分析 YOLOv5改进系列(1)——添加SE注意力机制 YOLOv5改进系

ES高级查询

ES中提供了一种强大的检索数据方式&#xff0c;这种检索方式称为Query DSL&#xff0c;这种方式的丰富查询语法让ES检索变得更强大&#xff0c;更简洁。 1.常见查询 1.1查询所有[match_all] match_all关键字&#xff1a;返回索引中的全部文档。 GET /products/_search { &…

【MFC实践】基于MFC向导C++制作计算器(附文件)

一、写在前面1.1 什么是MFC向导&#xff1f;1.2 使用MFC向导制作计算器1.3安装visual studio 2022和MFC插件 二、设计计算器界面1.1 新创建MFC项目1.2 设计计算器界面1.3 添加相关变量1.4 算法的一些问题及解决方式1.5 计算功能的实现1.6 其它功能的实现1.6.1 DEL功能1.6.2 C置…

关于白盒测试,这些技巧你得游刃有余~

对于很多刚开始学习软件测试的小伙伴来说&#xff0c;如果能尽早将黑盒、白盒测试弄明白&#xff0c;掌握两种测试的结论和基本原理&#xff0c;将对自己后期的学习有较好的帮助。今天&#xff0c;我们就来聊聊黑盒、白盒测试的相关话题。 1、黑盒测试的方法和小结 最常见黑盒…

C++标准学习--多线程

在以往多线程的实现的时候&#xff0c;都是自己去亲自创建线程&#xff0c;采用特殊flag 及锁控制线程的运转状态。这无可厚非&#xff0c;但又似乎有重复造轮子的嫌疑。最近发现了一个线程池的轮子&#xff0c;很不错&#xff0c;ZZ一下。 C多线程线程池&#xff08;全详解&a…

免费学习鸿蒙(HarmonyOS)开发,一些地址分享

HarmonyOS万物互联&#xff0c;从华为一系列的操作来看已经与iOS、Android形成三足鼎立之势了。 根据《澎湃新闻》的报道&#xff0c;已有23所985高校和46所211高校加入了鸿蒙班的行列&#xff0c;合计达到了69所国内一流高校。通过鸿蒙班的设立&#xff0c;高校可以为学生提供…

【Java】正则表达式( Pattern 和 Matcher 类)

快速入门 Java 提供了 java.util.regex 包&#xff0c;它包含了 Pattern 和 Matcher 类&#xff0c;用于处理正则表达式的匹配操作。 java.util.regex 包主要包括以下三个类&#xff1a; Pattern 类&#xff1a; pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共…

从Scroll怒喷社区用户事件,看L2龙头ZKFair的做事格局

这两天&#xff0c;随着美国SEC正式批准所有11只比特币现货ETF的消息公布&#xff0c;吸引了传统主流增量资金的入场&#xff0c;比特币多头一举将比特币干到了48000刀的位置&#xff0c;并随时向着前高发起了冲击。比特币的强势带动了其他加密资产的保障&#xff0c;整个加密市…

面试常见问题回答干货

1、请你自我介绍一下你自己&#xff1f; 回答提示&#xff1a;一般人回答这个问题过于平常&#xff0c;只说姓名、年龄、爱好、工作经验&#xff0c;这些在简历上都有。其实&#xff0c;企业最希望知道的是求职者能否胜任工作&#xff0c;包括&#xff1a;最强的技能、最深入研…

基于elementUI封装的带复选框el-checkbox的下拉多选el-select组件

效果图&#xff1a; 组件&#xff1a;MultipleSelect.vue <template><el-select v-model"selectValues" v-bind"$attrs" v-on"listeners" multiple placeholder"请选择" style"width: 50%" change"changeSel…