170 похожих чатов

Залип с ссылками и рекурсией. Есть данные в формате NestedSets,

отсортированные по порядку постройки дерева. Вроде все есть, но под конец дня не работает голова.

"1" => [ "lft"=> 1, "rgt"=> 12, "dpt"=> 0, "tree"=> 1],
"1.1" => [ "lft"=> 2, "rgt"=> 9, "dpt"=> 1, "tree"=> 1],
"1.1.1" => [ "lft"=> 3, "rgt"=> 8, "dpt"=> 2, "tree"=> 1],
"1.1.1.1" => [ "lft"=> 4, "rgt"=> 5, "dpt"=> 3, "tree"=> 1],
"1.1.1.2" => [ "lft"=> 6, "rgt"=> 7, "dpt"=> 3, "tree"=> 1],
"1.2" => [ "lft"=> 10, "rgt"=> 11, "dpt"=> 1, "tree"=> 1],
"2" => [ "lft"=> 1, "rgt"=> 2, "dpt"=> 0, "tree"=> 2],

Как их проще обойти чтоб построить дерево вида?
"1" => [
"children" => [
"1.1" => [
"children" => [
"1.1.1" => [
"children" => [
"1.1.1.1" => [
"children" => [],
],
"1.1.1.2" => [
"children" => [],
],
],
],
],
],
"1.2" => [
"children" => []
],
],
],
"2" => [
"children" => [],
],

2 ответов

4 просмотра

Если говнокод но быстро и бесспощfдно, то if else по ключу

а что сложного

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

Обсуждают сегодня

Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
а как ловят такое ghci> res <- getPos2 urlt 0 (alist !! 0) 200 ghci> res SearchAtom (Search "www.google.com" "/search?q=" "Haskell") "haskell.org" (SearchTS [(2024-05-06 07:...
Fedor
14
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Есть тут те у кого дети есть + 2 работы + в зал ходят + в семейной жизни все хорошо?
Abdul-Aziz M.
13
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
кто шарит: mattermost отслеживает что ты на пк запускаешь?
Valentin
13
Помогите, пожалуйста, делаю программу для для подсчёта корней квадратного уравнения, знаю, что есть куча недочётов, недоработок, но основная проблема в том, что почему-то при ...
NYC
13
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
Всем привет! Стоит задачка, выбрать из выпадающего списка конкретный цвет. Пока реализовал через активацию контрола списка и выбора несколькими нажатиями стрелки вправо до нуж...
Роман.С
9
Карта сайта