首页 > web前端 > js教程 > 正文

在 JavaScript 中查找括号分数

WBOY
发布: 2023-09-01 18:17:08
转载
1090 人浏览过

在 JavaScript 中查找括号分数

问题

我们需要编写一个 JavaScript 函数,该函数接受平衡的方括号字符串 str 作为第一个也是唯一的参数。

我们的函数应根据以下规则计算并返回字符串的分数 -

  • [] 的分数为 1

  • AB 的得分为 A + B,其中 A 和 B 是平衡括号字符串。
  • [A] 的得分为 2 * A,其中 A 是平衡括号字符串。

例如,如果函数的输入是

输入

const str = '[][]';
登录后复制

输出

const output = 2;
登录后复制

示例

以下是代码 -

const findScore = (str = '') => {
   const arr = []
   for(const char of str) {
      arr.push(char)
      while(arr[arr.length - 1] === ']') {
         arr.pop()
         if(arr[arr.length - 1] === '[') {
            arr.pop() arr.push(1)
         } else {
            let num = arr.pop()
            while(arr[arr.length - 1] >= 1) {
               num += arr.pop()
            }
            arr.pop()
            arr.push(2 * num)
         }
      }      
   }
   return arr.reduce((acc, a) => acc + a, 0)
};
console.log(findScore(str));
登录后复制

输出

2
登录后复制

以上是在 JavaScript 中查找括号分数的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!