题目描述
从一个长度为N的正数数组numbers中找出长度至少为L且几何平均值最大子数组,并输出其位置和大小。(K个数的几何平均值为K个数的乘积的K次方根)
若有多个子数组的几何平均值均为最大值,则输出长度最小的子数组。
若有多个长度相同的子数组的几何平均值均为最大值,则输出最前面的子数组。
输入描述
第一行输入为N、L
- N表示numbers的大小(1 ≤ N ≤ 100000)
- L表示子数组的最小长度(1 ≤ L ≤ N)
之后N行表示numbers中的N个数,每个一行(10^-9 ≤ numbers[i] ≤ 10^9)
输出描述
输出子数组的位置(从0开始计数)和大小,中间用一个空格隔开。
备注
- 用例保证除几何平均值为最大值的子数组外,其他子数组的几何平均值至少比最大值小10^-10倍
用例
| 输入 | 3 2 2 2 3 |
| 输出 | 1 2 |
| 说明 | 长度至少为2的子数组共三个,分别是{2,2}、{2,3}、{2,2,3}, |
该博客介绍了如何解决华为在线开发者(OD)面试中的一道几何平均值最大子数组问题。博主给出了详细的问题描述,包括输入输出要求,并强调了在几何平均值相等的情况下,应优先选择长度更短或位置更靠前的子数组。解决方案可能是通过编程实现,特别是使用Java语言进行求解。
订阅专栏 解锁全文
1316

被折叠的 条评论
为什么被折叠?



