Задать вопрос
@MishaXXL

Как составить дерево из вложенных значений в скобки?

Как составить дерево из вложенных значений?
(1 (20 (400 5 60 (700) 108 (90)) 3))
По какому принципу создается вложенность при обходе строки с учётом вложенности путем скобок?
  • Вопрос задан
  • 95 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
Alexandroppolus
@Alexandroppolus
кодир
конкретно в данном случае (только числа) можно воспользоваться парсингом JSON, предварительно доработав напильником строку
const result = JSON.parse(
  '(1 (20 (400 5 60 (700) 108 (90)) 3))'
  .replaceAll('(', '[')
  .replaceAll(')', ']')
  .replace(/(\d|\])(?=\s+\d|\s*\[)/g, '$&,'));


----
ну а если по-честному, то надо обходить строку, и либо рекурсией, либо со стеком.

Примерно так:
код внутри
function getTree(str) {
    const tokens = str.match(/\d+|[()]/g);

    const stack = [];
    let currentArr = null;

    for(let i = 0; i < tokens.length; ++i) {
        const token = tokens[i];
        if (token === ')') {
            if (!stack.length) {
                return currentArr;
            }
            currentArr = stack.pop();
        } else if (token === '(') {
            const newArr = [];
            if (currentArr) {
                currentArr.push(newArr);
                stack.push(currentArr);
            }
            currentArr = newArr;
        } else {
            if (currentArr) {
                currentArr.push(parseInt(token));
            }
        }
    }
    return currentArr;
}

const result = getTree('(1 (20 (400 5 60 (700) 108 (90)) 3))');


Сначала парсим строку, получаем токены, в нашем случае это скобки и числа. Обходим токены, имея на руках стек и текущий массив. Если очередной токен - число, добавляем его в текущий массив, если открывашка, то создаем новый массив, добавляем его в текущий, потом текущий кладем в стек, а новый назначаем текущим. Если закрывашка, то забираем массив из стека.
То же самое можно сделать через рекурсию, попробуй сам, если интересно.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы