Trie树C++(Acwing)

Trie树C++(Acwing)_第1张图片

Trie树C++(Acwing)_第2张图片

Trie树C++(Acwing)_第3张图片

Trie树C++(Acwing)_第4张图片

Trie树C++(Acwing)_第5张图片

Trie树C++(Acwing)_第6张图片

Trie树C++(Acwing)_第7张图片

Trie树C++(Acwing)_第8张图片

Trie树C++(Acwing)_第9张图片

Trie树C++(Acwing)_第10张图片

Trie树C++(Acwing)_第11张图片

Trie树C++(Acwing)_第12张图片

Trie树C++(Acwing)_第13张图片

Trie树C++(Acwing)_第14张图片

Trie树C++(Acwing)_第15张图片

Trie树C++(Acwing)_第16张图片

Trie树C++(Acwing)_第17张图片

Trie树C++(Acwing)_第18张图片

Trie树C++(Acwing)_第19张图片

代码:

#include 

using namespace std;

const int N = 100010;

int son[N][26], cnt[N], idx;
char str[N];

void insert(char str[])
{
    int p = 0;//从0结点开始往下插入
    for(int i = 0; str[i]; i++)//循环遍历字符串
    {
        int u = str[i] - 'a';//将26个字母映射成0到25
        if(!son[p][u]) son[p][u] = ++idx;//如果没有这个子结点就将其插入
        p = son[p][u];//然后p结点往下移    
    }
    
    cnt[p]++;//以p结尾字符串加一
}

int query(char str[])
{
    int p = 0;
    for(int i = 0; str[i]; i++)
    {
        int u = str[i] - 'a';
        if(!son[p][u]) return 0;
        p = son[p][u];    
    }
    
    return cnt[p];
}

int main()
{
    int n;
    scanf("%d", &n);
    while(n--)
    {
        char op[2];
        scanf("%s%s", op, str);
        if(op[0] == 'I') insert(str);
        else printf("%d\n", query(str));    
    }
    
    return 0;
}

你可能感兴趣的:(c++,数据结构,算法)