Назад к вопросам
Middle+
7
/** * Проверяет сбалансированы ли скобки в строке или нет. * Скобки, которые могут встретиться в строке: * [[{ и }]] * @param {string} str * @return {boolean} */ function parentheses(str) { const open = ['(', '[', '{']; const close = [')', ']', '}']; const stack = []; for (let i = 0; i < str.length; i++) { const letter = str[i]; if (open.includes(letter)) { stack.push(letter); } else if (close.includes(letter)) { const index = close.indexOf(letter); const lastOpenIndex = stack.length - 1; if (open[index] !== stack[lastOpenIndex]) { return false; } else { stack.splice(lastOpenIndex, 1); } } } return stack.length === 0; }
Компании, где спрашивали
Morizo
Ответ от нейросети
sobes.tech AI
Функция проверяет, сбалансированы ли скобки в строке, используя стек.
Идея:
- При открывающей скобке кладём её в стек.
- При закрывающей проверяем, соответствует ли она последней открытой (верхушке стека).
- Если нет — возвращаем false.
- В конце, если стек пуст, значит все скобки корректно закрыты.
Пример использования:
console.log(parentheses("{[()()]}") ); // true
console.log(parentheses("{[(])}") ); // false
Функция корректно обрабатывает круглые, квадратные и фигурные скобки.