算法学习--数据结构

简介: 算法学习--数据结构

Trie 树

Trie 树是用来快速存储和查找字符串集合的数据结结构


模板题 835. Trie 字符串统计 - AcWing 题库


#include<iostream>
using namespace std;
const int NN=100010;
int son[NN][26], cnt[NN], idx;
int n;
string op, s;
void insert(const string& str){
    int p=0; // 以0号点为根结点
    for(int i=0;str[i];i++){
        int u=str[i]-'a';
        if(son[p][u]==0){
            son[p][u]=++idx;
        }
        p=son[p][u]; // p 指针向下移动指针向下
    }
    cnt[p]++; // 对字符串的末尾作一个标记, 进行计数
}
int query(const string& str){
    int p=0;
    for(int i=0;str[i];i++){
        int u=str[i]-'a';
        if(son[p][u]==0) // 一旦有一个点没有找到, 则说明就是没有
            return 0;
        p=son[p][u];
    }
    return cnt[p];
}
int main(){
    int n;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>op>>s;
        if(op[0]=='I'){
            insert(s);
        }else{
            cout<<query(s)<<endl;
        }
    }
    return 0;
}


并查集


并查集支持如下操作:


  1. 将两个集合合并
  2. 查询两个元素是否在同一个集合当中


并查集中每个集合用一棵树进行实行, 每个集合的编号就是树中根结点的编号, 每个结点存储它的父结点, p[x] 表示 x 的父结点


  1. 判断树根 : if(p[x]==x)
  2. x的集合编号 : `while(p[x]!=x) x=p[x];
  3. 合并两个集合 : p[x]=y


模板题 836. 合并集合 - AcWing 题库


#include<iostream>
using namespace std;
const int NN=1e5+10;
int n,m;
string op;
int a,b;
int p[NN];
 // 寻找根节点, 也就是 u 所在的集合编号
int find(int u){
    if(p[u]!=u){
        p[u]=find(p[u]); // 路径压缩
    }
    return p[u];
}
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        p[i]=i;
    }
    for(int i=0;i<m;i++){
        cin>>op>>a>>b;
        if(op[0]=='M'){
            p[find(a)]=find(b); // a 的根节点的父节点置成 b 的父节点, 则完成了集合合并
        }
        else{
            if(find(a)==find(b)){
                cout<<"Yes"<<endl;
            }else{
                cout<<"No"<<endl;
            }
        }
    }
    return 0;
}
相关文章
|
6天前
|
存储 监控 NoSQL
Redis处理大量数据主要依赖于其内存存储结构、高效的数据结构和算法,以及一系列的优化策略
【5月更文挑战第15天】Redis处理大量数据依赖内存存储、高效数据结构和优化策略。选择合适的数据结构、利用批量操作减少网络开销、控制批量大小、使用Redis Cluster进行分布式存储、优化内存使用及监控调优是关键。通过这些方法,Redis能有效处理大量数据并保持高性能。
27 0
|
5天前
|
缓存 算法 Java
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
|
5天前
|
NoSQL 算法 Java
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
|
6天前
|
机器学习/深度学习 算法 网络架构
什么是神经网络学习中的反向传播算法?
什么是神经网络学习中的反向传播算法?
11 2
|
6天前
|
机器学习/深度学习 算法
算法人生(5):从“元学习”看“战胜拖延”(没兴趣版)
元学习是让机器学会学习策略,适应新任务的机器学习范式。通过定义任务分布、采样任务、内在和外在学习循环来优化模型,增强其跨任务适应性和泛化能力。面对不感兴趣的任务导致的拖延,我们可以借鉴元学习的思路:重新评估任务价值,寻找通用兴趣点;设定奖励激发行动;改变环境以提高执行力。通过调整视角、自我激励和优化环境,可以克服因无兴趣而产生的拖延。
|
6天前
|
机器学习/深度学习 存储 算法
算法人生(4):从“选项学习”看“战胜拖延”(担心失败版)
选项学习是强化学习的一种策略,通过定义、学习和切换选项来解决复杂任务,将大任务分解为可重复使用的子任务,以提高学习效率和适应性。面对因担心失败而拖延的问题,我们可以借鉴选项学习的思想:将大任务拆分为小目标,正视失败作为成长的一部分,回顾成功经验并寻求支持。通过这种方式,逐步增强自信,降低拖延现象。
|
6天前
|
算法 网络协议
【计网·湖科大·思科】实验三 总线型以太网的特性、集线器和交换机的区别、交换机的自学习算法
【计网·湖科大·思科】实验三 总线型以太网的特性、集线器和交换机的区别、交换机的自学习算法
8 1
|
6天前
|
机器学习/深度学习 算法 数据可视化
Python 数据结构和算法实用指南(四)(4)
Python 数据结构和算法实用指南(四)
14 1
|
6天前
|
机器学习/深度学习 存储 算法
Python 数据结构和算法实用指南(四)(3)
Python 数据结构和算法实用指南(四)
15 1
|
6天前
|
存储 算法 搜索推荐
Python 数据结构和算法实用指南(四)(2)
Python 数据结构和算法实用指南(四)
10 0