问题
我们需要编写一个 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 中查找括号分数的详细内容,更多请关注编程之家其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。