华为OD在线OJ:
已购买本专栏用户,请私信博主开通账号,在线刷题!!!
在线OJ:立即刷题
题库专栏:2023华为OD机试(A卷+B卷)(C++JavaJSPy)
题目描述
给定一个由若干整数组成的数组nums,请检查数组是否是由某个子数组重复循环拼接而成,请输出这个最小的子数组。
输入描述
第一行输入数组中元素个数n,1 ≤ n ≤ 100000
第二行输入数组的数字序列nums,以空格分割,0 ≤ nums[i] < 10
输出描述
输出最小的子数组的数字序列,以空格分割;
备注
数组本身是其最大的子数组,循环1次可生成的自身;
用例
输入
9
1 2 1 1 2 1 1 2 1
输出
1 2 1
说明
数组[1,2,1,1,2,1,1,2,1] 可由子数组[1,2,1]重复循环3次拼接而成
解题思路 :
题目要求找到一个最小的子数组,使得原数组可以由这个子数组重复循环拼接而成。为了解决这个问题,我们可以借鉴KMP算法中的next数组的构建思想。
- 首先,读取输入数据,包括数组长度和数组元素。
- 初始化一个next数组,用于存储KMP算法中的前缀信息。同时初始化两个索引,一个是前缀索引(prefixIndex),另一个是当前索引(currentIndex)。
- 使用KMP算法的思想构建next数组:
- 如果当前元素与前缀元素相等,更新next数组,并将当前索引和前缀索引同时向前移动。
- 如果前缀索引大于0,但当前元素与前缀元素不相等,将前缀索引回退到前一个前缀。
- 如果前缀索引为0