华为OD机试真题-数组合并【2023.Q1】

这篇博客介绍了一道华为在线测评(OD)的编程题,涉及将多个整数数组按照特定规则合并成一个新的数组。题目要求每次从每个数组中取出固定长度的内容,直至所有数组取完。解题思路包括将数组存储到队列中,然后依次按规则合并。参考代码给出了Java实现。

题目内容

现在有多组整数数组,需要将他们合并成一个新的数组。
合并规则,从每个数组里按顺序取出固定长度的内容合并到新的数组中,取完的内容会删除掉,如果该行不足固定长度或者已经为空,则直接取出剩余部分的内容放到新的数组中,继续下一行。如样例1,获得长度3,先遍历第一行,获得2,5,6;再遍历第二行,获得1,7,4;再循环回到第一行,获得7,9,5;再遍历第二行,获得3,4;再回到第一行,获得7,按顺序拼接成最终结果。
输入描述
第一行是每次读取的固定长度,0<长度<10;第二行是整数数组的数目0<数目<1000,
第3~n行是需要合并的数组,不同的数组用回车换行分隔,数组内部用逗号分隔。最大不超过100个元素
输出描述
输出一个新的数组,用逗号分隔
输入
3
2
2,5,6,7,9,5,7
1,7,4,3,4
输出
2,5,6,1,7,4,7,9,5,3,4,7

解题思路

将每个数组存储到LinkedList,再将所有 LinkedList 存储到 ArrayList 中。StringBuilder 用来记录合并后的数组。
当整数数组列表不为空时:

  1. 从当前数组中提取固定长度的元素,将它们添加到 StringBu
### 华为OD中的数组与二叉树题目解析 #### 题目描述 给定一个整数数组 `nums`,其中第一个元素代表根节点的值,后续元素按照完全二叉树的方式存储。对于任意索引 `i` (从1开始),其左子节点位于位置 `2*i` 而右子节点则处于 `2*i + 1` 的位置[^2]。 #### 解决方案概述 为了处理这类问题,可以采用递归的方法遍历这棵由数组构建起来的二叉树结构,并执行所需的操作。下面将以 Python 实现为例展示如何创建一棵基于输入数组的二叉树并对其进行前序遍历: ```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def array_to_binary_tree(nums): if not nums or nums[0] is None: return None root = TreeNode(nums[0]) queue = [root] i = 1 while i < len(nums): current_node = queue.pop(0) # 左孩子 if i < len(nums) and nums[i] is not None: current_node.left = TreeNode(nums[i]) queue.append(current_node.left) i += 1 # 右孩子 if i < len(nums) and i < len(nums) and nums[i] is not None: current_node.right = TreeNode(nums[i]) queue.append(current_node.right) i += 1 return root def preorder_traversal(root): result = [] stack = [root] while stack: node = stack.pop() if node: result.append(node.val) stack.append(node.right) stack.append(node.left) return result if __name__ == "__main__": test_array = [1, 2, 3, 4, 5, 6, 7] tree_root = array_to_binary_tree(test_array) print(preorder_traversal(tree_root)) ``` 此代码片段展示了如何将一个列表转换成对应的二叉树对象以及怎样通过栈来实现非递归版本的先序遍历算法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

AlgorithmHero

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

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

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

打赏作者

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

抵扣说明:

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

余额充值