在 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 中查找括号分数的详细内容,更多请关注双恒网络其它相关文章!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。



