华为OD机试真题---箱子之字形摆放

华为OD机试中的“箱子之字形摆放”问题是一个经典的数组处理和模拟算法问题。以下是对该问题的详细解析:

一、题目描述

有一批箱子,用一个字符串来表示每个箱子上的编号(编号由字母和数字组成)。要求将这批箱子按照之字形顺序摆放在宽度为n的空地上,并输出它们的摆放位置。之字形摆放要求每行的箱子是交替从左到右,或者从右到左摆放的,形成类似“Z”字形的排列。

二、输入描述

输入只有一行字符串,格式为“str n”,其中str是表示箱子的字符串,n是空地的宽度(也即每行可以摆放的箱子数量)。

三、输出描述

输出箱子的摆放结果,每行输出一组摆放好的箱子,并且不应该输出多余的空行。

四、解题思路

为了正确地按照之字形摆放箱子,可以将这个问题分解为以下几个步骤:

  1. 初始化矩阵:根据宽度n,创建一个二维数组(或列表),每一行用于存放按照之字形摆放的字符。
  2. 确定每个字符的位置:通过遍历字符串中的每个字符,使用行索引来确定字符应该放置在哪一行。如果当前字符应该从左往右摆放,则按照正常顺序填充;如果当前字符应该从右往左摆放,则需要将字符放置在倒数位置。
  3. 交替顺序控制:通过对当前字符的索引值进行模运算,判断当前行是需要从左到右还是从右到左摆放。可以通过一个标志位来控制当前行的摆放方向。
  4. 输出矩阵:最后将每一行的字符拼接成字符串输出。

五、具体实现

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class ZigZagBoxesSimplified {

    public static void main(String[] args) {
        // 创建Scanner对象以读取输入,本例中未使用输入,直接使用了定义好的字符串
        Scanner sc = new Scanner(System.in);
        // 定义一个包含字母和数字的字符串,用于后续处理
        String line = sc.nextLine();
        // 将字符串按空格分割为两部分,第一部分为字母串,第二部分为数字
        String[] strings = line.split(" ");
        // 将字符串中的数字转换为整数,用于确定列的宽度
        int n = Integer.parseInt(strings[1]);
        // map key用来存放每一行的下标,value对应的字符串
        Map<Integer, String> map = new HashMap<>();
        // 提取字母串,用于后续的处理
        String letterStr = strings[0];
        // 遍历字母串,根据列的宽度进行分组
        for (int i = 0; i < letterStr.length(); i++) {
            // 计算当前字符属于第几列
            int columnIdx = i/n;
            // 根据列的奇偶性决定字符的存放顺序
            int index;
            // 如果是偶数列,那么是正序,奇数列是倒序
            if (columnIdx % 2 == 0) {
                // 索引正序
                index = i % n;
            }else {
                // 如果是奇数列,那么是倒序
                index = n - 1 - i % n;
            }
            // 获取当前索引下的字符串,如果不存在则返回空字符串
            String str = map.getOrDefault(index, "");
            // 将当前字符添加到对应的字符串末尾
            String val = str + letterStr.charAt(i);
            // 将更新后的字符串存回map
            map.put(index, val);

        }
        // 遍历map,打印每一行的字符串
        for (int key : map.keySet()) {
            System.out.println(map.get(key));
        }


    }

}


六、示例

示例1

  • 输入:ABCDEFG 3
  • 输出:
AFG
BE
CD

示例2

  • 输入:HELLOWORLD 4
  • 输出:
HOD
ELW
LOR

(注意:由于示例2的字符串长度不是4的倍数,因此最后一行可能不满4个箱子,但这不影响之字形摆放的规则。)

七、运行示例解析

输入解析
  • 输入字符串为 ABCDEFG 3
  • strings[0]ABCDEFG,表示字母串。
  • strings[1]3,表示每列的宽度。
代码逻辑解析
  1. 初始化

    • 创建一个 Scanner 对象 sc 来读取输入(尽管在这个例子中未使用)。
    • 读取输入行 line 并将其按空格分割成 strings 数组。
    • strings[1] 转换为整数 n,即每列的宽度为 3。
    • 创建一个 HashMap map,键为整数(表示列中的行索引),值为字符串(表示该行中的字符)。
  2. 处理字母串

    • 遍历字母串 letterStr 中的每个字符。
    • 计算当前字符的列索引 columnIdx,使用 i / n(整数除法)。
    • 根据列索引的奇偶性决定字符在行中的位置:
      • 偶数列(0, 2, …):字符按正序添加到行中。
      • 奇数列(1, 3, …):字符按倒序添加到行中。
    • 计算字符在行中的索引 index
      • 偶数列:index = i % n
      • 奇数列:index = n - 1 - i % n
    • 使用 map.getOrDefault(index, "") 获取当前行索引下的字符串(如果不存在则为空字符串)。
    • 将当前字符添加到该字符串的末尾,并更新 map
  3. 输出结果

    • 遍历 map,按行索引的顺序打印每行的字符串。
运行示例解析

输入:ABCDEFG 3

  • 字母串:ABCDEFG
  • 列宽:3

处理过程

  • 字符 A

    • 列索引 0(偶数列)
    • 行索引 0index = 0 % 3 = 0
    • map 更新为 {0=A}
  • 字符 B

    • 列索引 0(偶数列)
    • 行索引 1index = 1 % 3 = 1
    • map 更新为 {0=A, 1=B}
  • 字符 C

    • 列索引 0(偶数列)
    • 行索引 2index = 2 % 3 = 2
    • map 更新为 {0=A, 1=B, 2=C}
  • 字符 D

    • 列索引 1(奇数列)
    • 行索引 2index = 3 - 1 - (0 % 3) = 2,倒序)
    • map 更新为 {0=A, 1=B, 2=CD}
  • 字符 E

    • 列索引 1(奇数列)
    • 行索引 1index = 3 - 1 - (1 % 3) = 1,倒序)
    • map 更新为 {0=A, 1=BE, 2=CD}
  • 字符 F

    • 列索引 1(奇数列)
    • 行索引 0index = 3 - 1 - (2 % 3) = 0,倒序)
    • map 更新为 {0=AF, 1=BE, 2=CD}
  • 字符 G

    • 列索引 2(偶数列)
    • 行索引 0index = 3 % 3 = 0
    • map 更新为 {0=AFG, 1=BE, 2=CD}

输出结果

AFG
BE
CD
简单来说就是

以输入ABCDEFG 3为例,详细步骤如下:

  • 初始化哈希表为空。
  • 处理字符A:列索引0(偶数列),行索引0,更新哈希表为{0=A}
  • 处理字符B:列索引0(偶数列),行索引1,更新哈希表为{0=A, 1=B}
  • 处理字符C:列索引0(偶数列),行索引2,更新哈希表为{0=A, 1=B, 2=C}
  • 处理字符D:列索引1(奇数列),行索引2(从右到左),更新哈希表为{0=A, 1=B, 2=CD}
  • 处理字符E:列索引1(奇数列),行索引1(从右到左),更新哈希表为{0=A, 1=BE, 2=CD}
  • 处理字符F:列索引1(奇数列),行索引0(从右到左),更新哈希表为{0=AF, 1=BE, 2=CD}
  • 处理字符G:列索引2(偶数列),行索引0,更新哈希表为{0=AFG, 1=BE, 2=CD}
  • 输出结果:
    AFG
    BE
    CD
    

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Knife4j在Gateway下的URI优化以及热刷新

Knife4j在Gateway下的URI优化以及热刷新 契机 &#xff08;遗留输出&#xff09;最近在整理之前的笔记&#xff0c;逐渐梳理成文章输出到博客网站。之前在做Gateway集成knife4j的时候。发现uri的地址缺少了项目路径&#xff0c;也就是baseURI&#xff0c;本篇文章就是在处理这…

Kubernates

kubernates是一个开源的&#xff0c;用于管理云平台中多个主机上的容器化的应用&#xff0c;Kubernetes的目标是让部署容器化的应用简单并且高效&#xff08;powerful&#xff09;,Kubernetes提供了应用部署&#xff0c;规划&#xff0c;更新&#xff0c;维护的一种机制。 架构…

前端开发 之 12个鼠标交互特效下【附完整源码】

前端开发 之 12个鼠标交互特效下【附完整源码】 文章目录 前端开发 之 12个鼠标交互特效下【附完整源码】七&#xff1a;粒子烟花绽放特效1.效果展示2.HTML完整代码 八&#xff1a;彩球释放特效1.效果展示2.HTML完整代码 九&#xff1a;雨滴掉落特效1.效果展示2.HTML完整代码 十…

重生之我在异世界学编程之C语言:深入预处理篇(上)

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文一、预处理的作用与流程&#xf…

Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现“刮刮乐”效果,Kotlin(2)

Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现“刮刮乐”效果&#xff0c;Kotlin&#xff08;2&#xff09; 在 Android使用PorterDuffXfermode的模式PorterDuff.Mode.SRC_OUT实现橡皮擦&#xff0c;Kotlin&#xff08;1&#xff09;-CSDN博客文章浏览阅…

修改 `invite_codes` 表中 `code` 字段名为 `invite_code`

-- auto-generated definition create table invite_codes (id int auto_incrementprimary key,code varchar(6) not null comment 邀请码&#xff0c;6位整数&#xff0c;确保在有效期内…

Python + 深度学习从 0 到 1(01 / 99)

希望对你有帮助呀&#xff01;&#xff01;&#x1f49c;&#x1f49c; 如有更好理解的思路&#xff0c;欢迎大家留言补充 ~ 一起加油叭 &#x1f4a6; 欢迎关注、订阅专栏 【深度学习从 0 到 1】谢谢你的支持&#xff01; ⭐ 深度学习之前&#xff1a;机器学习简史 什么要了解…

路径规划之启发式算法之二十三:免疫算法(Immune Algorithm,IA)

免疫算法(Immune Algorithm,IA)是基于人工免疫系统的理论,受生物免疫系统的启发而推出的一种新型的智能搜索算法。通过模拟生物免疫系统的工作原理来解决优化问题。 一、定义与原理 免疫算法是以人工免疫系统的理论为基础,实现了类似于生物免疫系统的抗原识别、细胞分化、…

echarts画风向杆

1.安装echarts 2.引入echarts 4.获取数据&#xff0c;转换数据格式 windProfile.title.text ${moment(time.searchTime[0], ‘YYYY-MM-DD HH:mm:ss’).format( ‘YYYY-MM-DD HH:mm’ )}-${moment(time.searchTime[1], ‘YYYY-MM-DD HH:mm:ss’).format(‘YYYY-MM-DD HH:mm’)…

【落羽的落羽 C语言篇】自定义类型——结构体

文章目录 一、结构体1. 结构体类型的概念和声明2. 结构体变量的创建和初始化3. 结构体成员的访问3.1 直接访问3.2 间接访问 4. 结构体的内存对齐4.1 内存对齐的规则4.2 内存对齐的原因4.3 修改默认对齐数 5. 结构体传参6. 结构体实现位段 在C语言中&#xff0c;已经提供了一些基…

CSS盒子模型(溢出隐藏,块级元素和行级元素的居中对齐,元素样式重置)

overflow&#xff1a;值 规定了内容溢出元素框时所发生的事情 visible&#xff1a;内容不会被修剪&#xff0c;会显示在元素框之外&#xff0c;默认值 overflow: visible; hidden&#xff1a;内容会被修剪&#xff0c;溢出内容不可见 overflow: hidden; scroll&#xff1a;内…

Spark-Streaming集成Kafka

Spark Streaming集成Kafka是生产上最多的方式&#xff0c;其中集成Kafka 0.10是较为简单的&#xff0c;即&#xff1a;Kafka分区和Spark分区之间是1:1的对应关系&#xff0c;以及对偏移量和元数据的访问。与高版本的Kafka Consumer API 集成时做了一些调整&#xff0c;下面我们…

【Python】pandas库---数据分析

大学毕业那年&#xff0c;你成了社会底层群众里&#xff0c;受教育程度最高的一批人。 前言 这是我自己学习Python的第四篇博客总结。后期我会继续把Python学习笔记开源至博客上。 上一期笔记有关Python的NumPy数据分析&#xff0c;没看过的同学可以去看看&#xff1a;【Pyt…

数字IC后端设计实现篇之TSMC 12nm TCD cell(Dummy TCD Cell)应该怎么加?

TSMC 12nm A72项目我们需要按照foundary的要求提前在floorplan阶段加好TCD Cell。这个cell是用来做工艺校准的。这个dummy TCD Cell也可以等后续Calibre 插dummy自动插。但咱们项目要求提前在floorplan阶段就先预先规划好位置。 TSCM12nm 1P9M的metal stack结构图如下图所示。…

LiteFlow决策系统的策略模式,顺序、最坏、投票、权重

个人博客&#xff1a;无奈何杨&#xff08;wnhyang&#xff09; 个人语雀&#xff1a;wnhyang 共享语雀&#xff1a;在线知识共享 Github&#xff1a;wnhyang - Overview 想必大家都有听过或做过职业和性格测试吧&#xff0c;尤其是现在的毕业生&#xff0c;在投了简历之后经…

YashanDB 23.2 YAC -单库多实例架构多活共享集群安装部署指南

一、概述 1.1 文档目标 ​ 本说明旨在指导技术人员在 CentOS 7 x86_64 操作系统上完成崖山数据库企业版 23.2 的共享集群安装与部署。通过系统架构、集群拓扑及部署需求的精确描述&#xff0c;帮助读者在开始安装前对崖山数据库的架构形成清晰认识。本文以高效、稳定、安全为…

某科技局国产服务器PVE虚拟化技术文档

环境介绍 硬件配置 服务器品牌&#xff1a;黄河 型号&#xff1a;Huanghe 2280 V2 Cpu型号&#xff1a;kunpeng-920 磁盘信息 :480SSD * 2 ,4T*4 网卡&#xff1a;板载四口千兆 如下表 四台服务器同等型号配置&#xff0c;均做单节点虚拟化&#xff0c;数据保护采用底层r…

Gin-vue-admin(4):项目创建前端一级页面和二级页面

目录 创建一级页面创建二级页面 创建一级页面 view目录下新建一个my&#xff0c;Index.vue <template></template><script> export default {name:My, } </script><script setup> import {ref} from vue const myNameref("name") &…

Ubuntu下的tcl/tk编程快速入门

一、Tcl/Tk 简介 接口介绍 https://www.tutorialspoint.com/tcl-tk/tcl_tk_quick_guide.htm GUI Canvas接口 https://www.tutorialspoint.com/tcl-tk/tk_canvas_widgets.htm tcl语言 https://www.tcl-lang.org/ 官方教程 https://www.tcl.tk/man/tcl8.5/tutorial/tcltutoria…

数字化审计咨询服务,企业转型数字化审计的必要条件

人工智能、云计算、大数据、物联网等新兴技术的快速发展&#xff0c;为企业的数字化转型提供了强大的技术支持。这些技术逐渐被应用到企业运营管理的方方面面&#xff0c;推动了企业内部审计工作的变革。随着数字化转型的深化和信息技术的不断发展&#xff0c;数字化审计将成为…