Acwing835Trie字符串统计

题目

维护一个字符串集合,支持两种操作:

  1. I x 向集合中插入一个字符串 x
  2. Q x 询问一个字符串在集合中出现了多少次。

共有 N 个操作,所有输入的字符串总长度不超过 105105,字符串仅包含小写英文字母。

输入格式

第一行包含整数 N,表示操作数。

接下来 N 行,每行包含一个操作指令,指令为 I xQ x 中的一种。

输出格式

对于每个询问指令 Q x,都要输出一个整数作为结果,表示 x 在集合中出现的次数。

每个结果占一行。

数据范围

1≤N≤2∗10^4

输入样例:

css 复制代码
5
I abc
Q abc
Q ab
I ab
Q ab

输出样例:

1
0
1

代码

java 复制代码
import java.util.Scanner;

public class Main {
    static int N = 100010, idx;
    static int[][] son = new int[N][26];  // 存储字母节点的二维数组,每个节点最多有 26 个子节点
    static int[] cnt = new int[N];  // 记录每个节点对应的单词数量

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();  // 输入操作次数
        while (n > 0) {
            n--;
            String command = in.next();  // 读取操作指令
            switch (command) {
                case "I":
                    String s = in.next();  // 读取待插入的字符串
                    insert(s);  // 调用插入函数
                    break;
                case "Q":
                    String st = in.next();  // 读取待查询的字符串
                    System.out.println(query(st));  // 输出查询结果
                    break;
            }
        }
    }

    // 查询函数,返回以字符串 st 为前缀的单词数量
    private static int query(String st) {
        int p = 0;  // 初始化根节点
        for (int i = 0; i < st.length(); i++) {
            char c = st.charAt(i);  // 获取字符串中的每个字符
            int u = c - 'a';  // 计算字符对应的索引
            if (son[p][u] == 0) son[p][u] = ++idx;  // 如果当前节点没有该子节点,则创建一个新节点
            p = son[p][u];  // 移动到下一个节点
        }
        return cnt[p];  // 返回以字符串 st 为前缀的单词数量
    }

    // 插入函数,将字符串 s 插入到字典树中
    private static void insert(String s) {
        int p = 0;  // 初始化根节点
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);  // 获取字符串中的每个字符
            int u = c - 'a';  // 计算字符对应的索引
            if (son[p][u] == 0) son[p][u] = ++idx;  // 如果当前节点没有该子节点,则创建一个新节点
            p = son[p][u];  // 移动到下一个节点
        }
        cnt[p]++;  // 更新以字符串 s 为前缀的单词数量
    }
}
相关推荐
夜月行者1 小时前
如何使用ssm实现基于SSM的宠物服务平台的设计与实现+vue
java·后端·ssm
Yvemil71 小时前
RabbitMQ 入门到精通指南
开发语言·后端·ruby
sdg_advance1 小时前
Spring Cloud之OpenFeign的具体实践
后端·spring cloud·openfeign
猿java2 小时前
使用 Kafka面临的挑战
java·后端·kafka
碳苯2 小时前
【rCore OS 开源操作系统】Rust 枚举与模式匹配
开发语言·人工智能·后端·rust·操作系统·os
kylinxjd2 小时前
spring boot发送邮件
java·spring boot·后端·发送email邮件
2401_857439695 小时前
Spring Boot新闻推荐系统:用户体验优化
spring boot·后端·ux
进击的女IT6 小时前
SpringBoot上传图片实现本地存储以及实现直接上传阿里云OSS
java·spring boot·后端
一 乐7 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
艾伦~耶格尔10 小时前
Spring Boot 三层架构开发模式入门
java·spring boot·后端·架构·三层架构