首页 > web前端 > js教程 > 使用 JavaScript 获取数组中山的最大长度

使用 JavaScript 获取数组中山的最大长度

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2023-08-24 12:25:08
转载
568 人浏览过

使用 JavaScript 获取数组中山的最大长度

山子序列

如果满足以下属性,我们将任何(连续)子数组 sub(arr)称为山 -

  • sub.length >= 3

  • 存在一些 0 B[i+1] > ... > sub[sub.length - 1]

问题

我们需要编写一个 JavaScript 函数,该函数接受数字数组 arr 作为第一个也是唯一的参数。

我们的函数应该返回最大山子序列的长度存在于数组arr中,如果存在,则为0。

例如,如果函数的输入为

输入

const arr = [3, 2, 5, 8, 4, 3, 6];
登录后复制

输出

const output = 5;
登录后复制

输出解释

因为所需的子数组是 -

[2, 5, 8, 4, 3]
登录后复制

示例

以下是代码 -

 实时演示

const arr = [3, 2, 5, 8, 4, 3, 6];
const mountainLength = (arr = []) => {
   let max = 0
   for(let left = 0; left < arr.length; left++) {
      let right = left
      while(arr[right] < arr[right + 1]) {
         right++
      }
      const top = right
      while(right > left && arr[right] > arr[right + 1]) {
         right++
      }
      if(right > top && top > left) {
         max = Math.max(max, right - left + 1)
         left = right
         left--
      }
   }
   return max
}
console.log(mountainLength(arr));
登录后复制

输出

5
登录后复制

以上是使用 JavaScript 获取数组中山的最大长度的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板