华为OD机试真题B卷 JavaScript实现【报文重排序】,附详细解题思路

news2024/11/19 1:20:30

在这里插入图片描述

一、题目描述

对报文进行重传和重排序是常用的可靠性机制,重传缓冲区内有一定数量的子报文,每个子报文在原始报文中的顺序已知,现在需要恢复出原始报文。

二、输入描述

输入第一行为N,表示子报文的个数,0 < N <= 1000。

输入第二行为N个子报文,以空格分开,子报文格式为字符串报文内容+后缀顺序索引,字符串报文内容由[a-z,A-Z]组成,后缀为整形值,表示顺序。顺序值唯一,不重复。

三、输出描述

输出恢复出的原始报文。

按照每个子报文的顺序的升序排序恢复出原始报文,顺序后缀需要从恢复出的报文中删除掉。

四、解题思路

题目要求根据子报文的顺序索引恢复出原始报文。子报文由报文内容和顺序索引组成,报文内容是字符串,顺序索引是整数。

解题思路如下:

  1. 读取输入的子报文个数N;
  2. 读取输入的N个子报文,并解析每个子报文的报文内容和顺序索引;
  3. 使用一个哈希表letterMap存储顺序索引和报文内容的对应关系;
  4. 遍历顺序索引从1到N,按照顺序从letterMap中取出对应的报文内容,并拼接到结果字符串res中;
  5. 输出res作为恢复出的原始报文。

解题思路分析:

该算法首先将输入的子报文解析并存储到哈希表中,哈希表的键为顺序索引,值为报文内容。然后按照顺序从1到N依次从哈希表中取出报文内容,将其拼接到结果字符串中。最终输出结果字符串作为恢复出的原始报文。算法的时间复杂度为O(N),其中N为子报文的个数。

五、JavaScript算法源码

import java.util.*;

public class Main{
 
    public static void main(String[] args) {
 
        Scanner sc = new Scanner(System.in);
 
        int N = sc.nextInt();
        sc.nextLine();
        String[] strings = sc.nextLine().split(" ");
 
        Map<Integer, String> letterMap = new HashMap<>();
        for(int i=0; i<strings.length; i++){
            String str = strings[i];
            //防止空格
            if(str.equals("")){
                continue;
            }
            //数字开始的下标
            int index = 0;
            for(int j=0; j<str.length(); j++){
                if(Character.isDigit(str.charAt(j))){
                    index = j;
                    break;
                }
            }
            //字母部分
            String letter = str.substring(0, index);
            //顺序部分
            int num = Integer.parseInt(str.substring(index));
            letterMap.put(num, letter);
        }
 
        String res = "";
        for(int i=1; i<=N; i++){
            res += letterMap.get(i) + " ";
        }
 
        System.out.println(res.substring(0, res.length() - 1));
    }
}

六、效果展示

1、输入

6
nezha1,study2,java3,is4,very5,good6

2、输出

nezhastudyjavaisverygood

3、说明

在这里插入图片描述


🏆下一篇:华为OD机试真题 JavaScript 实现【相对开音节】【2022Q4 100分】,附详细解题思路

🏆本文收录于,华为OD机试(JavaScript)真题(A卷+B卷)

每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

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

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

相关文章

chatgpt赋能python:Python建模:从入门到精通

Python建模&#xff1a;从入门到精通 Python是一种高级编程语言&#xff0c;已经成为了机器学习和数据科学领域的事实标准。因为Python比其他语言更容易学习和上手&#xff0c;所以它是入门级开发人员和数据科学家的首选语言。 在本文中&#xff0c;我们将介绍Python建模的基…

深入解析IT专业分类、方向及就业前景:高考毕业生如何选择适合自己的IT专业?重点探索近年来人工智能专业发展及人才需求

目录 一、IT专业的就业前景和发展趋势二、了解IT专业的分类和方向三、你对本专业的看法和感想四、本专业对人能力素养的要求五、建议和思考其它资料下载 当今社会&#xff0c;信息技术行业以其迅猛的发展和无限的潜力成为了吸引无数年轻人的热门选择。特别是对于高考毕业生来说…

10.面向对象编程(高级部分)|Java学习笔记

文章目录 类变量和类方法类变量类变量使用注意事项和细节 类方法类方法使用注意事项和细节 理解 main 方法语法代码块代码块使用注意事项和细节讨论 单例设计模式单例模式应用实例饿汉式 VS 懒汉式 final 关键字final 使用注意事项和细节 抽象类抽象类的介绍抽象类使用的注意事…

Vue中如何进行文件压缩与解压缩?

Vue中如何进行文件压缩与解压缩&#xff1f; 在前端开发中&#xff0c;文件的压缩和解压缩是经常需要用到的功能。尤其是在需要上传和下载文件的场景下&#xff0c;文件压缩可以减小文件大小&#xff0c;加快文件传输速度&#xff0c;提高用户体验。本文将介绍在Vue项目中如何…

纷享销客王亚辉:聚焦终端,打造医疗健康行业管理新高度

1.医疗健康行业持续增长的关键 是数字化经营客户价值 随着生活水平和生活质量的不断提高&#xff0c;人们的医疗健康意识日渐增强&#xff0c;对医疗健康的需求越来越强烈&#xff1b;同时&#xff0c;国家政策的扶持再加上人口老龄化进程加快&#xff0c;进一步推动着医疗健…

【spring源码系列-05】refresh中prepareRefresh方法的执行流程

Spring源码系列整体栏目 内容链接地址【一】spring源码整体概述https://blog.csdn.net/zhenghuishengq/article/details/130940885【二】通过refresh方法剖析IOC的整体流程https://blog.csdn.net/zhenghuishengq/article/details/131003428【三】xml配置文件启动spring时refres…

003、体系结构之TiKV持久化

TiKV架构和作用 数据持久化分布式一致性MVCC分布式事务Coprocessor coprocessor : 协同处理器。 可以将一些SQL计算交给TiKV处理。不需要将TiKV所有数据通过网络发送给TiDB Server RocksDB 任何持久化的存储引擎&#xff0c;数据终归要保存在磁盘上&#xff0c;TiKV 也不例外…

NeRF in the wild 论文解读与公式推导

NeRF in the Wild: Neural Radiance Fields for Unconstrained Photo Collections 论文&#xff1a;https://openaccess.thecvf.com/content/CVPR2021/papers/Martin-Brualla_NeRF_in_the_Wild_Neural_Radiance_Fields_for_Unconstrained_Photo_CVPR_2021_paper.pdfhttps://op…

不同等级的Pads工程师,薪资差距有多大?

作为一种广泛应用在PCB设计的EDA工具&#xff0c;Pads软件在中国的电子设计行业中有着重要地位&#xff0c;尤其是不同等级的Pads工程师&#xff0c;在薪资、工作范围等有很大的差异&#xff0c;本文将从中国出发&#xff0c;多方面分析对比不同等级的Pads工程师&#xff0c;希…

监控、审计和运行时安全

监控、审计和运行时安全 目录 文章目录 监控、审计和运行时安全目录1、分析容器系统调用&#xff1a;SysdigSysdig介绍安装sysdigsysdig常用参数sysdig常用命令Chisels(实用的工具箱)其它命令 2、监控容器运行时&#xff1a;FalcoFalco介绍Falco架构安装falco自定义扩展规则文件…

ElasticSearch(ES)介绍

前言 为什么学习ElasticSearch&#xff1f; 1、ElasticSearch具备非常强的大数据分析能力。虽然Hadoop也可以做大数据分析&#xff0c;但是ElasticSearch的分析能力非常高&#xff0c;具备Hadoop不具备的能力。比如有时候用Hadoop分析一个结果&#xff0c;可能等待的时间比较…

免费获取程序员好书,这个宝藏网站等你来挖!

今天给大家分享一个免费的程序员、IT、互联网资源的​免费书籍网站。​ 书籍类型涵盖了Vue、CSS、小程序等前端语言、框架&#xff1b;.NET、JAVA、Go等后端语言&#xff1b;Android、IOS、Flutter等移动语言&#xff1b;数据库、云计算大数据、网络系统运维、UI美工设计、游戏…

【CASA模型】生态系统NPP及碳源、碳汇模拟、土地利用变化、未来气候变化、空间动态模拟实践技术应用

查看原文>>>生态系统NPP及碳源、碳汇模拟、土地利用变化、未来气候变化、空间动态模拟实践技术应用 由于全球变暖、大气中温室气体浓度逐年增加等问题的出现&#xff0c;“双碳”行动特别是碳中和已经在世界范围形成广泛影响。碳中和可以从碳排放&#xff08;碳源&am…

Jmeter调用Oracle、pg、MySql 储存过程,实例,获取返回值

JDBC Request: 1、重要参数说明&#xff1a; Variable Name&#xff1a;数据库连接池的名字&#xff0c;需要与JDBC Connection Configuration的Variable Name Bound Pool名字保持一致   Query&#xff1a;填写的sql语句未尾不要加“;”   Parameter valus&#xff1a;参数…

统信UOS系统开发笔记(四):从Qt源码编译安装之编译安装QtCreator4.11.2,并配置编译测试Demo

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/131182539 红胖子(红模仿)的博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软…

激光雷达安全系统:让世界变得更安全

基于3D激光雷达的安全系统具有更高的可靠性,减少了误报,因此具有更高级别的安全性。激光雷达在安全和监视应用中越来越受欢迎,由于其高可靠性、远程、厘米级精度以及对具有挑战性的天气和照明条件不敏感等特点,它很容易击败相机或雷达等同行。 01 基于激光雷达的安全系统 …

技术文章—基于SPAD / SiPM技术的激光雷达方案

激光雷达(LiDAR)是一种测距技术,近年来越来越多地用于汽车先进驾驶辅助系统(ADAS)、手势识别和3D映射等应用。尤其在汽车领域,随着传感器融合的趋势,LiDAR结合成像、超声波、毫米波雷达,互为补足,为汽车提供全方位感知,为迈向更安全的自动驾驶铺平道路。安森美半导体提供…

简历项目合集

基于Arduino的超声波悬浮装置 超声波悬浮原理 项目图片 概述 实验需要使用Arduino驱动换能器产生一个40KHz的方波&#xff0c;可以使用换能器组&#xff0c;也可以使用Arduino的超声波模块。但是仅仅使用Arduino输出的方波信号的功率&#xff0c;并不足以使得小物体悬浮&…

【AI人工智能】 iTab浏览器标签页中最强大的AI功能莫过于此了, 你不用真的太可惜了! 最后一步就这样干(3)

&#x1f680; 个人主页 极客小俊 ✍&#x1f3fb; 作者简介&#xff1a;web开发者、设计师、技术分享博主 &#x1f40b; 希望大家多多支持一下, 我们一起进步&#xff01;&#x1f604; &#x1f3c5; 如果文章对你有帮助的话&#xff0c;欢迎评论 &#x1f4ac;点赞&#x1…

对windows自带EFS加解密的研究

0x00 前言 0x01 测试环境 windows7专业版SP1&#xff1a; 在虚拟机中运行&#xff0c;创建了快照&#xff0c;当前账户名和密码为jizong/123456 0x02 EFS加解密原理&#xff1a; EFS加密实际上综合了对称加密和不对称加密&#xff0c;具体流程如下&#xff1a; (1) 随机生…