Пишу простое дерево поиска с одной деталью: в каждой вершине

храню размер поддерева этой веришны, структура выглядит вот так:

struct Node {
key: i64,
left_ptr: Option<Box<Node>>,
right_ptr: Option<Box<Node>>,
size: usize,
}

для вставки и удаления написал общую функцию обхода, дело только в том, что для поддержания корректного состояния Node.size в случае если элемент найден/не найден, либо уменьшать значения size у всех предков по пути к искомой вершине, либо не уменьшать - в зависимости от выполнения условия соответственно. для этого надо поддерживать Vec<&mut Option<Box<Node>>>, в который на каждом шаге обхода дерева добавлять ссылку на вершину в конец. В итоге выходит так, что в коде возникает повторный borrowing мутабельных ссылок. Как мне правильно откорректировать решение, чтобы все было правильно?

7 ответов

16 просмотров

Не совсем понимаю задачу. Вам надо обновлять size каждой ноды при вставке/удалении из дерева? Вставка/удаление будут делаться через корень дерева, и делаться рекурсией? Тогда не нужна доп ссылка на ноды дерева, можно менять size рекурсивно post order

Pavel-Danilov Автор вопроса

а вот рекурсивное рабочее решение я написал, хочется не рекурсивное. по идее же как-то можно сымитировать стек, чтобы в нерекурсивном тоже все работало

Pavel Danilov
а вот рекурсивное рабочее решение я написал, хочет...

С этим не подскажу. В си или крестах это решается стеком на хипе с мутабельными ссылками на ноды дерева. В расте такое по идее тоже должно работать (дерево будет владеть нодами, стек - мутаьельно ссылаться)

Pavel Danilov
а вот рекурсивное рабочее решение я написал, хочет...

Рекурсивное работает из-за reborrowing мутабельных ссылок. Для итеративного нужно в одном скоупе держать и мутабельную ссылку на корень и мутабельную ссылку на поддерево - в rust этого сделать нельзя. Или unsafe и указатели или что я выше написал

Pavel-Danilov Автор вопроса
Pavel Danilov
а зачем на корень держать?

чтобы имитировать стек. На корень и на все остальные по пути до текущей вершины

Pavel-Danilov Автор вопроса
red75prime
чтобы имитировать стек. На корень и на все остальн...

а когда мы спускаемся по дереву вниз, считается, что все вершины, которые мы прошли, они в статусе borrowed?

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Ребята привет. Telegraf 3.38 актуален ещё или лучше обновиться?
𝙊𝑙ẽ𝘨 // Rabbit Hole
2
Есть ли лимиты на кол-во вебхук по домену? Стоит в данный момент 900+ ботов и бывает бот перестает отвечать (не приходят вебхуки) 🐒 Помогает только перезапуск
ᅠ [ Кому не ответил, дублируйте ]
11
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Товарищи, я с вопросом На сколько мне известно, это, конечно, зависит от того, как программа использует процессор, но у меня всё равно остаётся вопрос Допустим, есть 2 проце...
Shen
1
Товарищи, здравствуйте Подскажите, пожалуйста, может кто-нибудь сталкивался с такой задачей Через вебапку можно сканировать qr-код, а есть ли возможность считывать nfc?
Artem Stormageddon
8
Визуальное отображение моделей таблиц sql какое посоветуете?
Shen
7
Коллеги, здравствуйте Подскажите, пожалуйста. я почему-то всегда думал, что если переходить по ссылке такого формата(t.me/bot_bot?start=1) на бота. То бот сразу прожимает кн...
Artem Stormageddon
3
Карта сайта