题目
维护一个字符串集合,支持两种操作:
 1."Ix"向集合中插入一个字符串x;
 2."Qx”询问一个字符串在集合中出现了多少次。
 共有N个操作,输入的字符串总长度不超过 
     
      
       
       
         1 
        
        
        
          0 
         
        
          5 
         
        
       
      
        10^5 
       
      
    105,字符串仅包含小写英文字母。
输入格式
第一行包含整数N,表示操作数。
 接下来N行,每行包含一个操作指令,指令为"L×"或"Qx"中的一种。
输出格式
对于每个询问指令"Qx”,都要输出一个整数作为结果,表示x在集合中出现的次数。每个结果占一行。
数据范围
1 ≤ N ≤ 2 ∗ 1 0 4 1 \le N \le 2*10^4 1≤N≤2∗104
- 输入样例:
 
5
I abc
Q abc
Q ab
I ab
Q ab
 
- 输出样例:
 
1
0
1
 
题解
import java.util.Scanner;
/**
 * @author akuya
 * @create 2023-06-27-11:29
 */
public class Trie {
    static int N=100010;
    static int n,idx=0;
    static int son[][]=new int[N][26];
    static int cnt[]=new int [N];
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        n=scanner.nextInt();
        while(n--!=0){
            String op=scanner.next();
            String str=scanner.next();
            if(op.equals("I"))insert(str);
            if(op.equals("Q")) System.out.println( query(str));;
        }
    }
    public static void insert(String s){
        int p=0;
        char str[]=s.toCharArray();
        for(int i=0;i<str.length;i++){
            int u=str[i]-'a';
            if(son[p][u]==0)son[p][u]=++idx;
            p=son[p][u];
        }
        cnt[p]++;
    }
    public static int query(String s){
        int p=0;
        char str[]=s.toCharArray();
        for(int i=0;i<str.length;i++){
            int u=str[i]-'a';
            if(son[p][u]==0) return 0;
            p=son[p][u];
        }
        return cnt[p];
    }
}
 
思路
本题为点播学习trie树的结构,何为trie的树,以下图片为模板:



















