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

Камраден, а кто ткнёт носом в С++ example для Patricia

trie из libstdc++ с бинарными ключами?
А то даже гугл не помогает что-то...

Ну то есть со строками-то всё понятно, делай так:
typedef trie<string, null_type, trie_string_access_traits<>, pat_trie_tag, trie_prefix_search_node_update> pref_trie;
и вперёд.

А как для бинарных данных (да тех же uint32_t) - осознать не получается.

Для rd-tree всё понятно, делай так::
typedef tree<int, null_type, less<int>, rb_tree_tag, tree_order_statistics_node_update> ordered_set;

Но если вместо rb_tree_tag указать pat_trie_tag ( https://gcc.gnu.org/onlinedocs/libstdc++/ext/pb_ds/trie_based_containers.html ), то less<int> уже не подходит, надо какой-то аналог trie_string_access_traits<>, которого в libstd++ нет.
Ну или ещё чего не хватает - не может он темплейт инстанцировать.

Подскажите, куда копать?

1 ответов

13 просмотров
Andrey-Kulikov Автор вопроса

Ответ нашелся в неожиданном месте: https://github.com/sikol/patricia Там на примере IPv6-адресов как раз префиксный поиск: https://github.com/sikol/patricia/blob/master/tests/ip_prefix.cxx#L111

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
1
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Карта сайта