【数据结构】字典树

模板 于是他错误的点名开始了

时间复杂度 O ( n ∣ S ∣ ) O(n|S|) O(n∣S∣)

cpp 复制代码
const int N=1e6+5,C=1e6+10,mod=1e9+7,inf=1e9+10;
struct trie{
    //计数数组 访问次数 孩子数组
    int cnt[N],tp[N],ch[N][30];
    int id=0;
    void insert(string s){//插入每一个字符串
        int p=0;
        for(auto c:s){
            int j=c-'a';
            if(!ch[p][j])ch[p][j]=++id;//孩子没有编号的安排编号
            p=ch[p][j];//跳到孩子
            //cnt[p]++放在这里 记录经过的次数
        }
        cnt[p]++;//记录每个串个数
    }
    void query(string s){//询问每个字符串状态
        int p=0;//和insert大致相同
        for(auto c:s){
            int j=c-'a';
            if(!ch[p][j])return cout<<"WRONG"<<endl,void();
            p=ch[p][j];
        }
        tp[p]++;
        if(cnt[p]==0)cout<<"WRONG"<<endl;
        else if(tp[p]>1)cout<<"REPEAT"<<endl;
        else cout<<"OK"<<endl;
    }
}t;
void solve() {
	int n,m;cin>>n;
    forr(i,1,n){
        string s;cin>>s;
        t.insert(s);
    }
    cin>>m;
    forr(i,1,m){
        string s;cin>>s;
        t.query(s);
    }
    cout<<t.id<<endl;
}

最长异或路径

cpp 复制代码
const int N=1e6+5,C=1e6+10,mod=1e9+7,inf=1e9+10;
struct trie{
    int ch[N*32][2],id=0;
    void insert(int s){
        int p=0;
        reforr(i,0,30){
            int j=s>>i&1;//从高位到低位 从上到下
            if(!ch[p][j])ch[p][j]=++id;
            p=ch[p][j];
        }
    }
    int query(int s){
        int p=0,res=0;
        reforr(i,0,30){
            int j=s>>i&1;
            if(ch[p][!j]){
                res+=(1<<i);
                p=ch[p][!j];
            }else p=ch[p][j];
        }
        return res;
    }
}t;
vector<pii>e[N];
int sum[N];
void dfs(int now,int fa){
    for(auto [x,w]:e[now]){
        if(fa==x)continue;
        sum[x]=w^sum[now];
        dfs(x,now);
    }
}
void solve() {
	int n;cin>>n;
    forr(i,1,n-1){
        int u,v,w;cin>>u>>v>>w;
        e[u].push_back({v,w});
        e[v].push_back({u,w});
    }
    dfs(1,0);
    forr(i,1,n)t.insert(sum[i]);//把x->1的异或路径值放进去
    int ans=0;
    forr(i,1,n)ans=max(ans,sum[i]);
    forr(i,1,n)ans=max(ans,t.query(sum[i]));//两两最大异或和
    cout<<ans<<endl;
}
相关推荐
侯小啾1 小时前
【03】C语言 强制类型转换 与 进制转换
c语言·数据结构·算法
Xの哲學2 小时前
Linux NAPI 架构详解
linux·网络·算法·架构·边缘计算
京东零售技术5 小时前
扛起技术大梁的零售校招生们 | 1024技术人特别篇
算法
爱coding的橙子6 小时前
每日算法刷题Day78:10.23:leetcode 一般树7道题,用时1h30min
算法·leetcode·深度优先
Swift社区6 小时前
LeetCode 403 - 青蛙过河
算法·leetcode·职场和发展
地平线开发者6 小时前
三种 Badcase 精度验证方案详解与 hbm_infer 部署实录
算法·自动驾驶
papership6 小时前
【入门级-算法-5、数值处理算法:高精度的减法】
算法·1024程序员节
lingran__6 小时前
算法沉淀第十天(牛客2025秋季算法编程训练联赛2-基础组 和 奇怪的电梯)
c++·算法
DuHz6 小时前
基于MIMO FMCW雷达的二维角度分析多径抑制技术——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
一二学长7 小时前
快速排序(JAVA详细讲解快速排序的四种方式)
数据结构