前缀搜索树的使用例子(PHP实现)

文章背景

根据PM的期望,我们最终需要给出归类好的数据让用户便捷查看。为啥不用MySQL的group by 是因为数据来源是其它系统的ES结果。

前缀树的作用

trie tree 译为前缀树或字典树。因为子孙节点的前缀都一样的关系,我们可以用它做路由、单词联想、归类排序等。

因为需求要为搜索页做同类分组,方便用户查看。因此思路是用 trie tree 分类然后按照子叶的后缀搜索顺序将乱掉的商品数据做排序。(看最后)

预期结果

php 复制代码
$line = [
            [1, 3, 2, 4, 5, 6, 7],
            [2, 3, 2, 4, 5, 6, 7],
            [2, 3, 1, 4, 5],
            [1, 3, 2, 4, 5, 7, 6],
        ];

代码

php 复制代码
public function insert3(array $parts, int $height, &$tree = [])
    {
        if (count($parts) <= $height) {
            $tree['isEnd'] = true;
            return;
        }
        $part  = $parts[$height];
        [$key,$child] = $this->mathChild($tree['children'], $part);
        if ($height == 0 ) {
            $this->warn(json_encode($tree['children']));
        }
        if ( ! $child) {
            $child = $this->newTrie($part);
            $this->insert3($parts, $height + 1, $child);
            $tree['children'][] = $child;
        } else {
            // 下面这一段非常地重要,它决定了同级兄弟成员
            $this->insert3($parts, $height + 1, $tree['children'][$key]);
        }
    }

public function mathChild(array $children, mixed $part)
    {
        foreach ($children as $key => $child) {
            if ($child['part'] == $part) {
                return [
                    $key,
                    $child,
                ];
            }
        }
        return null;
    }
private function newTrie(mixed $part): array
    {
        return [
            'children' => [],
            'isEnd'    => false,
            'part'     => $part,
        ];
    }
    
public function init()
{
    $line = [
            [1, 3, 2, 4, 5, 6, 7],
            [2, 3, 2, 4, 5, 6, 7],
            [2, 3, 1, 4, 5],
            [1, 3, 2, 4, 5, 7, 6],
        ];
    $tree = $this->newTrie('/');
        foreach ($line as $item) {
            $this->insert3($item, 0, $tree);
        }
    echo json_encode($tree, 256);
}

结果Json

ruby 复制代码
{"children":[{"children":[{"children":[{"children":[{"children":[{"children":[{"children":[{"children":[],"isEnd":true,"part":7}],"isEnd":false,"part":6},{"children":[{"children":[],"isEnd":true,"part":6}],"isEnd":false,"part":7}],"isEnd":false,"part":5}],"isEnd":false,"part":4}],"isEnd":false,"part":2}],"isEnd":false,"part":3}],"isEnd":false,"part":1},{"children":[{"children":[{"children":[{"children":[{"children":[{"children":[{"children":[],"isEnd":true,"part":7}],"isEnd":false,"part":6}],"isEnd":false,"part":5}],"isEnd":false,"part":4}],"isEnd":false,"part":2},{"children":[{"children":[{"children":[],"isEnd":true,"part":5}],"isEnd":false,"part":4}],"isEnd":false,"part":1}],"isEnd":false,"part":3}],"isEnd":false,"part":2}],"isEnd":false,"part":"\/"}

需求背景

现状

期望

相关推荐
图码1 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组
Cthy_hy1 小时前
树状数组(BIT)进阶:差分优化实现区间修改、区间查询
数据结构·python·算法
谢白羽3 小时前
agent memory论文解析一:解析项目(a-mem)
开发语言·php·论文·agent·a-mem·实际项目
代码中介商3 小时前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
Sarvartha5 小时前
单链表的顺序建立与结点的删除(期末题复现)
数据结构
Dlrb12116 小时前
数据结构-链表
数据结构·链表·逻辑结构·单向链表·物理结构·valgrind工具
小的~~6 小时前
算法题:只出现一次的数字
数据结构·算法
轻刀快马6 小时前
讲透分布式系统的演进史与核心架构
开发语言·架构·php
一切皆是因缘际会6 小时前
从概率拟合到内生心智:七层投影架构重构AGI数字生命新范式
大数据·数据结构·人工智能·重构·架构·agi
历程里程碑7 小时前
56 . 高效ET非阻塞IO服务器设计指南
java·运维·服务器·开发语言·数据结构·c++·排序算法