LeetCode、1268. 搜索推荐系统【中等,前缀树+优先队列、排序+前缀匹配】

文章目录

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、1268. 搜索推荐系统【中等,前缀树+优先队列、排序+前缀匹配】

题目类型及分类

题目链接:LeetCode、1268. 搜索推荐系统

分类:02数据结构/树/字典树(前缀树)


思路

API调用(排序+前缀匹配)

复杂度分析:时间复杂度O(n.logn);空间复杂度O(n)

java 复制代码
class Solution {

    //prodcuts数量2万  单词1000
    public List<List<String>> suggestedProducts(String[] products, String searchWord) {
        //根据字典序排序
        Arrays.sort(products);
        //初始化结果集合
        List<List<String>> ans = new ArrayList<>();
        //遍历所有的搜索文字
        for (int i = 0; i < searchWord.length(); i ++) {
            String s = searchWord.substring(0, i + 1);
            //结果集合
            List<String> res = new ArrayList<>();
            //遍历所有products
            for (String product: products) {
                if (product.startsWith(s)) {
                    res.add(product);
                }
                //若是已经收集到3个
                if (res.size() == 3) {
                    break;
                }
            }
            ans.add(res);
        }
        return ans;
    }
}

前缀树+优先队列

使用大顶堆目的:每个单词只留下3个最小字典序的,因为一旦大顶堆中有>目标数量时,就会将最大的排除出去。

复杂度分析:时间复杂度O(n);空间复杂度O(n)

java 复制代码
class Solution {

    //每一个大顶堆中的数量为3
    private static final int size = 3;
    //根节点
    private TrieNode root = new TrieNode();

    //自定义Node节点
    class TrieNode {
        public static final int num = 26;
        TrieNode[] children;
        boolean isEnd;
        PriorityQueue<String> queue;

        public TrieNode() {
            this.children = new TrieNode[num];
            this.queue = new PriorityQueue<>((o1,o2)->o2.compareTo(o1));
        }
    }

    //插入一个产品名称到前缀树
    public void insert(String product) {
        //拿到当前的前缀树节点
        TrieNode node = this.root;
        //遍历整个名称字符
        for (char ch: product.toCharArray()) {
            int index = ch - 'a';
            if (node.children[index] == null) {
                node.children[index] = new TrieNode();
            }
            node = node.children[index];
            //当前节点要将单词添加进来
            node.queue.offer(product);
            if (node.queue.size() > size) {
                node.queue.poll();
            }
        }
        node.isEnd = true;
    }

    public List<List<String>> suggestedProducts(String[] products, String searchWord) {
        List<List<String>> ans = new ArrayList<>();
        //遍历所有的商品名称,依次添加到前缀树中
        for (String product: products) {
            insert(product);
        }
        //搜索所有的匹配结果
        TrieNode node = this.root;
        for (char ch: searchWord.toCharArray()) {
            int index = ch - 'a';
            //临时保存一个集合
            List<String> tmp = new ArrayList<>();            
            if (node == null) {
                ans.add(tmp);
                continue;
            }
            node = node.children[index];
            //节点不为空情况
            while (node != null && !node.queue.isEmpty()) {
                tmp.add(node.queue.poll());
            }
            //将整个集合翻转
            Collections.reverse(tmp);
            //添加到最终的结果集合中
            ans.add(tmp);
        }
        return ans;
    }

}

资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 时间:2024.2.13

相关推荐
only-qi10 分钟前
leetcode2. 两数相加
算法·leetcode
鲨莎分不晴11 分钟前
拯救暗淡图像:深度解析直方图均衡化(原理、公式与计算)
人工智能·算法·机器学习
DuHz29 分钟前
242-267 GHz双基地超外差雷达系统:面向精密太赫兹传感与成像的65nm CMOS实现——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
AI科技星1 小时前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
2401_841495641 小时前
【LeetCode刷题】寻找重复数
数据结构·python·算法·leetcode·链表·数组·重复数
罗技1232 小时前
Easysearch 集群监控实战(下):线程池、索引、查询、段合并性能指标详解
前端·javascript·算法
一路往蓝-Anbo2 小时前
C语言从句柄到对象 (七) —— 给对象加把锁:RTOS 环境下的并发安全
java·c语言·开发语言·stm32·单片机·嵌入式硬件·算法
中國龍在廣州2 小时前
谈谈2025年人工智能现状及发展趋势分析
人工智能·深度学习·算法·自然语言处理·chatgpt·机器人·机器人学习
C雨后彩虹2 小时前
二维伞的雨滴效应
java·数据结构·算法·华为·面试
youngee113 小时前
hot100-60子集
数据结构·算法