大约 1 分钟
- Algorithm87
- ACM3
- 全栈1
- npm1
- 脚手架1
- 开源项目2
- 我的世界10
- 项目实战23
- API开放平台1
- Java21
- Jenkins1
- Centos2
- vim1
- mysql2
- 二叉树1
- 哈希表1
- 字符串1
- 数组3
- 栈与队列1
- 链表1
- 基础算法3
- 动态规划16
- 字符串哈希1
- 数据结构2
- 数学知识6
- 搜索1
- DFS1
- 图论8
- 计算几何1
- Leetcode2
- ArrayList1
- HashMap1
- JUC并发编程1
- JUC1
- 反射1
- MyBatis1
- Mybatis-plus1
- Spring3
- SpringBoot1
- 中间件8
- MinIO1
- MongoDB1
- RabbitMQ3
- Redis2
- WebSocket1
- 微服务1
- freemarker1
- java1
- nginx1
- Easy Excel1
- 地图API1
- 微信公众号1
- MySQL4
- 面试1
- 设计模式1
- fabric5
- C++2
- GitHub5
- git1
- 工具2
- Linux8
- Macos1
- 技巧3
- 插件1
- 图床1
- Mac2
- 内网穿透1
- Gitee1
- hexo1
- iterm22
- 前端4
- React1
- TypeScript1
- Vue31
- openlayers61
- ES61
- 大学9
- Android1
- 操作系统1
- 数据库原理1
- 算法分析基础2
- 计算机组成原理2
- 计算机网络1
- 软件工程1
- 数据库1
- Docker1
- 服务器3
- Vim1
- 环境搭建1
- SSH1
- Maven1
- IDEA1
- ikun伙伴匹配系统6
- 用户中心5
- 谷粒商城3
- 黑马头条1
- 黑马点评7
- Codeforces38
ACM常用代码模版
数据结构
并查集
struct DSU {
std::vector<int> f, siz;
DSU(int n) {
f.resize(n + 1);
siz.resize(n + 1);
for (int i = 1; i <= n; i++) {
f[i] = i;
siz[i] = 1;
}
}
int find(int x) {
if (x != f[x]) f[x] = find(f[x]);
return f[x];
}
bool same(int x, int y) {
return find(x) == find(y);
}
bool merge(int x, int y) {
x = find(x);
y = find(y);
if (x == y) {
return false;
}
siz[x] += siz[y];
f[y] = x;
return true;
}
int size(int x) {
return siz[find(x)];
}
};
小于 1 分钟
C++的STL容器在ACM算法竞赛中的应用
一些有用的函数
is_sorted(a.begin(),a.end(),cmp);
判断是否按照cmp中的规则排序,默认升序
用法:
vector<int> a(10);
bool ok = is_sorted(a.begin() + 1, a.end());
cout << ok << endl;
大约 3 分钟