力扣算法Algorithm竞赛模板库(codeforces-go):含了算法竞赛中常用的数据结构和算法实现,助力开发者更高效地解决问题

1.算法Algorithm竞赛模板库(codeforces-go)

算法竞赛模板库,为算法竞赛爱好者提供了一系列精心设计的算法模板。这个库包含了算法竞赛中常用的数据结构和算法实现,助力开发者更高效地解决问题

在这里插入图片描述

一个算法模板应当涵盖以下几点:

  • 对该算法的基本介绍(核心思想、复杂度等)
  • 参考链接或书籍章节(讲的比较好的资料)
  • 模板代码(可以包含一些注释、使用说明)
  • 模板补充内容(常见题型中的额外代码、建模技巧等)
  • 相关题目链接(模板题、经典题、思维转换题等)

1.1 算法目录

不了解 Go?快速入门教程

  • 集合论与位运算

1.1.1 数据结构

  • 单调栈 monotone_stack.go
  • 单调队列 monotone_queue.go
    • 二维单调队列
  • 双端队列 deque.go
  • 堆(优先队列)heap.go
    • 支持修改、删除指定元素的堆
    • 懒删除堆
    • 对顶维
    • 前缀中位数
    • 滑动窗口前 k 小元素和
  • 并查集 union_find.go
    • 点权并查集
    • 边权并查集(种类并查集)
    • 可持久化并查集
    • 回滚并查集 & 动态图连通性
  • 稀疏表(ST 表)sparse_table.go
  • 树状数组 fenwick_tree.go
    • 差分树状数组(支持区间加、区间求和)
    • 树套树 & 三维偏序
  • 线段树 segment_tree.go
    • 线段树二分
    • 延迟标记(懒标记)
    • 动态开点
    • 线段树合并
    • 线段树分裂
    • 持久化(主席树)
  • 0-1 线段树 segment_tree01.go
  • 左偏树(可并堆)leftist_tree.go
  • 笛卡尔树 cartesian_tree.go
  • 二叉搜索树公共方法 bst.go
  • Treap treap.go
    • 前 k 小元素和
  • 伸展树 splay.go
  • 动态树 LCT link_cut_tree.go
  • 红黑树 red_black_tree.go
  • 替罪羊树 scapegoat_tree.go
  • k-d 树 kd_tree.go
  • 珂朵莉树(ODT)
    • 数组版 odt.go
    • 平衡树版 odt_bst.go
  • 根号分治、分块 sqrt_decomposition.go
  • 莫队算法 mo.go
    • 普通莫队
    • 带修莫队
    • 回滚莫队
    • 树上莫队

1.1.2 字符串 strings.go

  • 字符串哈希
  • KMP
    • pi 函数
    • border
    • 最小循环节
    • fail 树(失配树 / border 树)
  • 扩展 KMP(Z algorithm)
  • 最小表示法
  • 最长回文子串
    • Manacher 算法
  • 回文自动机(回文树,PAM)pam.go
  • 后缀数组(SA)
  • 后缀自动机(SAM)sam.go
  • 字典树 trie.go
    • 可持久化字典树
  • 0-1 字典树 trie01.go
    • 最大异或和
    • 第 k 大异或和
    • 删除元素
    • 可持久化 0-1 字典树
    • 【研究】0-1 字典树上最多有多少个节点
  • AC 自动机 acam.go

1.1.3 数学

  • 数论 math.go
    • 辗转相除法(最大公因数 GCD)
    • 类欧几里得算法 ∑⌊(ai+b)/m⌋
    • Pollard-Rho 质因数分解算法
    • 埃氏筛(埃拉托斯特尼筛法)
    • 欧拉筛(线性筛)
    • 欧拉函数
    • 原根
    • 扩展 GCD
      • 二元一次不定方程
    • 逆元
      • 线性求逆元
    • 中国剩余定理(CRT)
      • 扩展中国剩余定理
    • 离散对数
    • 大步小步算法(BSGS)
      • 扩展大步小步算法
    • 二次剩余
    • Jacobi 符号
    • N 次剩余
    • 卢卡斯定理
      • 扩展卢卡斯定理
    • 卡特兰数
    • 默慈金数
    • 那罗延数
    • 斯特林数
      • 第一类斯特林数(轮换)
      • 第二类斯特林数(子集)
    • 贝尔数
    • 欧拉数
    • 数论分块(整除分块)
    • 莫比乌斯函数
    • 莫比乌斯反演
      • 互质计数问题
      • GCD 求和问题
    • 杜教筛
  • 组合数学 math_comb.go
    • 常见模型
    • 常用恒等式
    • 容斥原理
  • 快速傅里叶变换 FFT math_fft.go
  • 快速数论变换 NTT math_ntt.go
    • 包含多项式全家桶(求逆、开方等等)
  • 快速沃尔什变换 FWT math_fwt.go
  • 连分数、佩尔方程 math_continued_fraction.go
  • 线性代数 math_matrix.go
    • 矩阵相关运算
    • 高斯消元
    • 行列式
    • 线性基
  • 数值分析 math_numerical_analysis.go
    • 自适应辛普森积分
    • 拉格朗日插值
  • 计算几何 geometry.go
    • 线与点
    • 线与线
    • 圆与点
      • 最小圆覆盖
        • Welzl 随机增量法
      • 固定半径覆盖最多点
    • 圆与线
    • 圆与圆
    • 圆与矩形
    • 最近点对
    • 多边形与点
      • 判断点在凸多边形内 O(log n)
      • 判断点在任意多边形内
        • 转角法(统计绕数)
    • 凸包
    • 最远点对
      • 旋转卡壳
    • 半平面交
  • 博弈论 games.go
    • SG 函数

1.1.4 动态规划 dp.go

  • 背包
    • 0-1 背包
    • 完全背包
    • 多重背包
      • 二进制优化
      • 单调队列优化
      • 同余前缀和优化(求方案数)
    • 分组背包
    • 树上背包(依赖背包)
    • 字典序最小方案
  • 线性 DP
    • 最大子段和
    • LCS
    • LPS
    • LIS
      • 狄尔沃斯定理
    • LCIS
    • 长度为 m 的 LIS 个数
    • 本质不同子序列个数
  • 区间 DP
  • 环形 DP
  • 博弈 DP
  • 概率 DP
  • 期望 DP
  • 状压 DP
    • 全排列 DP
    • 旅行商问题(TSP)
    • 子集 DP
    • 高维前缀和(SOS DP)
    • 插头 DP
  • 数位 DP
    • 记忆化搜索(同时跑上下界)
  • 倍增优化 DP
  • 斜率优化 DP(CHT)
  • WQS 二分优化 DP(凸优化 DP / 带权二分)
  • 树形 DP
    • 树的直径个数
    • 在任一直径上的节点个数
    • 树上最大独立集
    • 树上最小顶点覆盖
    • 树上最小支配集
    • 树上最大匹配
    • 换根 DP(二次扫描法)

1.1.5 图论 graph.go

  • 链式前向星
  • DFS 常用技巧
  • BFS 常用技巧
  • 欧拉回路和欧拉路径
    • 无向图
    • 有向图
  • 割点
  • 割边(桥)
  • 双连通分量(BCC)
    • v-BCC
    • e-BCC
  • 仙人掌 & 圆方树
  • 最短路
    • Dijkstra
    • SPFA(队列优化的 Bellman-Ford)
      • 差分约束系统
    • Floyd-Warshall
    • Johnson
    • 0-1 BFS(双端队列 BFS)
    • 字典序最小最短路
    • 同余最短路
  • 最小环
  • 最小斯坦纳树
  • 最小生成树(MST)
    • Kruskal
    • Prim
  • 单度限制最小生成树
  • 次小生成树
  • 曼哈顿距离最小生成树
  • 最小差值生成树
  • 最小树形图
    • 朱刘算法
  • 二分图判定(染色)
  • 二分图找奇环
  • 二分图最大匹配
    • 匈牙利算法
  • 带权二分图最大完美匹配
    • Kuhn–Munkres 算法
  • 拓扑排序
  • 强连通分量(SCC)
    • Kosaraju
    • Tarjan
  • 2-SAT
  • 基环树
  • 最大流
    • Dinic
    • ISAP
    • HLPP
  • 最小费用最大流
    • SPFA
    • Dijkstra
  • 三元环计数
  • 四元环计数
  • 树上问题 graph_tree.go
    • 直径
    • 重心
    • 点分治
    • 点分树
    • 最近公共祖先(LCA)
      • 倍增
      • ST 表
      • Tarjan
      • 树上差分
      • 虚树
    • 重链剖分(HLD)
    • 长链剖分
    • 树上启发式合并(small to large)
      • 按大小合并
      • 轻重儿子合并
    • 树分块
    • Prufer 序列

1.1.6 其他

  • 位运算笔记 bits.go
    • bitset
    • 区间位运算 trick(含 GCD)
  • 二分 三分 sort.go
    • 二分答案
    • 0-1 分数规划
    • 整体二分
  • 搜索 search.go
    • 枚举排列
    • 枚举组合
    • 生成下一个排列
    • 康托展开
    • 逆康托展开
    • 枚举子集
      • Gosper’s Hack
    • 折半枚举(Meet in the middle)
      • 超大背包问题
  • 随机算法 rand.go
    • 模拟退火
  • 基础算法 common.go
    • 算法思路整理
    • 滑动窗口
    • 前缀和
    • 二维前缀和
    • 二维差分
    • 离散化
  • 杂项 misc.go
  • 快速输入输出模板 io.go

1.2 如何选择题目 How to Choose Problems

1.2.1 Rating < 2100

这一阶段主要目标是提高对问题的观察能力。做构造题可以针对性地训练这一点。

选择难度在自己 rating 到 rating+200 范围内的构造题 (tag: constructive algorithms),按照过题人数降序做题,比如 [1700,1900] 区间的就是下面这个链接:

https://codeforces.com/problemset?order=BY_SOLVED_DESC&tags=constructive+algorithms%2C1700-1900

通过大量的构造题训练,提高观察能力,快速找到切题入口。具体见我在知乎上的这篇 回答。

1.2.2 Rating >= 2100(个人训练用,仅供参考)

见识更高的山、更广的海。

按人数从高到低,做 2200+ 的题目。建议不设置难度上限!由于按人数排序,难度分不会太高,不设上限可以避免错过高分好题

  • 构造题 2200+:锻炼手玩能力。
  • DP 2200+:几乎每场都有 DP。
  • 数学综合:数论、组合数学、概率期望等 2200+:包含 6 个 tag。
  • 图论综合:图论+树上问题 2200+:包含 7 个 tag。
  • 字符串 2200+:数据结构题不好筛选,可以找树状数组/线段树的题单,这里只单独筛选字符串的题。
  • 交互 2200+:偶尔做做,了解一些解题套路。
  • 博弈 2000+:也适合锻炼手玩。由于题目比较少,从 2000 开始筛选。

1.3 测试及对拍 Testing

编写一个 run(io.Reader, io.Writer) 函数来处理输入输出。这样写的理由是:

  • main 中调用 run(os.Stdin, os.Stdout) 来执行代码;
  • 测试时,将测试数据转换成 strings.Reader 当作输入,并用一个 strings.Builder 来接收输出,将这二者传入 run 中,然后就能比较输出与答案了;
  • 对拍时需要实现一个暴力算法 runAC,参数和 run 一样。通过 随机数据生成器 来生成数据,分别传入 runACrun,通过比对各自的输出,来检查 run 中的问题。

具体可以见 Codeforces 代码仓库 main,所有非交互题的代码及其对应测试全部按照上述框架实现。

例如:1439C_test.go

交互题的写法要复杂一些,需要把涉及输入输出的地方抽象成接口,详见 interactive_problem。

2. 学习资料及题目 Resources

2.1 常见资料收集

注:由于入门经典上选了很多区域赛的题,一部分题目可以在 GYM 上找到,这样可以就可以用 Go 编程提交了。

算法竞赛入门经典(第二版)

算法竞赛入门经典训练指南

算法竞赛入门经典训练指南(升级版)

算法竞赛进阶指南

算法竞赛入门到进阶

《算法竞赛》配套题单

OI Public Library(含国家队论文)

算法竞赛 (ICPC, OI, etc) 论文,课件,文档,笔记等

算法竞赛课件分享 by hzwer

算法第四版 Java 源码

数据结构和算法动态可视化

OI Wiki

CP-Algorithms

The Ultimate Topic List (with Resources, Problems and Templates)

洛谷日报

All the good tutorials found for Competitive Programming

Codeforces Problem Topics

The Ultimate Topic List(with Tutorials, Problems, and Templates)

GeeksforGeeks 上的算法合集

Pepcy 模板

F0RE1GNERS 模板

https://github.com/hh2048/XCPC 含 jiangly 模板

https://www.cnblogs.com/alex-wei/p/contents.html

【模板整合计划】目录

算法学习笔记(目录)

洛谷模板题(建议按难度筛选)

能力全面提升综合题单

Luogu Problem List

洛谷原试炼场

Links of ICPC/CCPC Contests from China

AtCoder 题目分类

2.2 AtCoder 版《挑战程序设计竞赛》

AtCoder 版!蟻本 (初級編)

AtCoder 版!蟻本 (中級編)

AtCoder 版!蟻本 (上級編)

AtCoder 版!蟻本 (発展的トピック編)

2.3 待整理

【杂文】记一些有用的神奇网站

偶然在 GitHub 上发现的超长列表

算法竞赛训练中较难的部分

算法竞赛中可能不太会遇到的论文题

[杂谈]OI/ACM中冷门算法

Things I don’t know

[meme] If you know at least 3 of these things and you are not red — you are doing it wrong. Stop learning useless algorithms, go and solve some problems, learn how to use binary search.

https://blog.csdn.net/calabash_boy/article/details/79973483

https://github.com/zimpha/algorithmic-library

https://www.luogu.com.cn/blog/command-block/blog-suo-yin-zhi-ding-post

https://wcysai.github.io/

https://www.luogu.com.cn/blog/Troverld/index

C++ @cache

2.4 其他 Others

My GoLand Live Templates and Postfix Completion settings

Useful Tools

GeoGebra

Draw Geometry

Draw Graph

OEIS

Wolfram|Alpha

UpSolve.me

Codeforces Upsolving Helper

Contests Filter

Codeforced

Codeforces Visualizer

Codeforces Solve Tracker

Another Codeforces Solve Tracker

AtCoder Problems

AtCoder Companions

AtCoder-Codeforces Rating converter

Rating and Difficulties

Open Codeforces Rating System

How to Interpret Contest Ratings

Codeforces: Problem Difficulties

Elo rating system

Stay Healthy

Exercises!

视频链接可以看:b站 灵茶山艾府 https://space.bilibili.com/206214

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/697398.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言------字符串函数(2)

1.strcat函数功能实现 ​ char* mystrcat(char* dest, const char* src) {assert(dest);assert(src);char* ret dest;//找到目标空间里面的斜杠0的位置&#xff0c;再追加while (*dest ! \0){dest;}while ((*dest *src)){;}return ret; } int main() {char arr1[20] "…

【信息系统项目管理师】--【信息技术发展】--【现代化创新发展】--【物联网】

文章目录 第二章 信息技术发展2.2 新一代信息技术及应用2.2.1 物联网1.技术基础2.关键技术3.应用和发展 第二章 信息技术发展 信息技术是在信息科学的基本原理和方法下&#xff0c;获取信息、处理信息、传输信息和使用信息的应用技术总称。从信息技术的发展过程来看&#xff0c…

Android 圆环带刻度条进度动画效果实现

效果图 需求是根据传感器做一个重力球效果&#xff0c;先实现了动画后续加上跟传感器联动. 又是摆烂的一天&#xff0c; 尚能呼吸&#xff0c;未来可期啊 View源码 package com.android.circlescalebar.view;import android.content.Context; import android.content.res.Typ…

C++ //练习 7.58 下面的静态数据成员的声明和定义有错误吗?请解释原因。

C Primer&#xff08;第5版&#xff09; 练习 7.58 练习 7.58 下面的静态数据成员的声明和定义有错误吗&#xff1f;请解释原因。 //example.h class Example{public:static double rate 6.5;static const int vecSize 20;static vector<double> vec(vecSize); };//e…

【治愈系】心灵鸡汤美文:温暖你的每一寸心田

1.人生就像一杯茶&#xff0c;不会苦一辈子&#xff0c;但总会苦一阵子。只有经历过苦涩&#xff0c;才能品味到甜美的滋味。 2.每一次失败都是一次宝贵的经验&#xff0c;它教会我们如何更好地面对困难和挑战。不要害怕失败&#xff0c;因为失败是成功的前奏。 3.人生最重要的…

【Vue】本地使用 axios 调用第三方接口并处理跨域

前端处理跨域 一. 开发准备 开发工具&#xff1a;VScode框架&#xff1a;Vue2项目结构&#xff1a;vue脚手架生成的标准项目&#xff08;以下仅显示主要部分&#xff09; 本地已搭建好的端口&#xff1a;8080要请求的第三方接口&#xff1a;http://1.11.1.111:端口号/xxx-api…

删除文件中的注释(C语言)

【题目描述】删除文件中的注释&#xff1a;将C语言源程序(hello.c)文件中的所有注释去掉后存入另一个文件(new_hello.c)。试编写相应程序。 【代码】 #include <stdio.h> #include <stdlib.h> int main(void) {FILE *fp1, *fp2;if ((fp1fopen("hello.c"…

【Git工具实战】实用真实 Git 开发工作流程

前言 最近工作中发现&#xff0c;很多开发人员连最基本的Git怎么使用都不知道&#xff0c;比如什么时候切分支&#xff0c;什么时候合并代码&#xff0c;代码遇到冲突怎么办&#xff0c;经常出现掉代码&#xff0c;代码合并后丢失的情况。以下为个人总结的常规Git开发工作流程…

Java架构师之路五、微服务:微服务架构、服务注册与发现、服务治理、服务监控、容器化等。

目录 微服务架构&#xff1a; 服务注册与发现&#xff1a; 服务治理&#xff1a; 服务监控&#xff1a; 容器化&#xff1a; 上篇&#xff1a;Java架构师之路四、分布式系统&#xff1a;分布式架构、分布式数据存储、分布式事务、分布式锁、分布式缓存、分布式消息中间件、…

C语言系列15——C语言的安全性与防御性编程

目录 写在开头1 缓冲区溢出&#xff1a;如何防范与处理1.1 缓冲区溢出的原因1.2 预防与处理策略 2. 安全的字符串处理函数与使用技巧2.1 strncpy函数2.2 snprintf函数2.3 strlcpy函数2.4 使用技巧 3 防御性编程的基本原则与实际方法3.1 基本原则3.2 实际方法 写在最后 写在开头…

思腾合力携京东打造服务器采购解决方案,助企业高校提升算力

随着云计算、大数据、人工智能的快速发展&#xff0c;服务器需求不断扩大&#xff0c;市场规模持续保持增长。IDC数据显示&#xff0c;预计2023年我国服务器市场规模将增至308亿美元。基于对服务器市场的趋势洞察&#xff0c;思腾合力携手京东品牌持续深化合作&#xff0c;在保…

深入浅出JVM(六)之前端编译过程与语法糖原理

本篇文章将围绕Java中的编译器&#xff0c;深入浅出的解析前端编译的流程、泛型、条件编译、增强for循环、可变长参数、lambda表达式等语法糖原理 编译器与执行引擎 编译器 Java中的编译器不止一种&#xff0c;Java编译器可以分为&#xff1a;前端编译器、即时编译器和提前编…

(提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战

文章目录 &#xff08;提供数据集下载&#xff09;基于大语言模型LangChain与ChatGLM3-6B本地知识库调优&#xff1a;数据集优化、参数调整、提示词Prompt优化本地知识库目标操作步骤问答测试的预设问题原始数据情况数据集优化&#xff1a;预处理&#xff0c;先后准备了三份数据…

mac下C、C++项目出现‘stdio.h’ file not found的解决方法

【转载】https://www.cnblogs.com/yongfengnice/p/14260997.html 有时候更新mac系统或者项目配置之后&#xff0c;打开之前的项目&#xff0c;发现出现莫名其妙的‘stdio.h’ file not found等头文件找不到。 解决这个问题之前&#xff0c;我们要弄清楚开发工具是引用了系统哪…

C++:STL简介

1. 什么是STL STL(standard template libaray- 标准模板库 ) &#xff1a; 是 C 标准库的重要组成部分 &#xff0c;不仅是一个可复用的组件库&#xff0c;而且 是一个包罗数据结构与算法的软件框架 。 2. STL的版本 3. STL的六大组件 4.STL的缺陷 1. STL库的更新太慢了。这…

用于将Grafana默认数据库sqlite3迁移到MySQL数据库

以下是一个方案&#xff0c;用于将Grafana数据迁移到MySQL数据库。 背景: grafana 默认采用的是sqlite3&#xff0c;当我们要以集群形式部署的时使用mysql较为方便&#xff0c;试了很多sqlite转mysql的方法要么收费,最后放弃。选择自己动手风衣足食。 目标: 迁移sqlite3切换…

速评谷歌开源大模型Gemma 7B

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…

day16_ListSet课后练习题 - 参考答案

文章目录 day16_课后练习题第1题第2题第3题第4题第5题第6题第7题第8题 day16_课后练习题 第1题 案例&#xff1a; ​ 1、用一个String[]数组存点数 ​ 2、用一个String[]数组存花色 ​ 3、用一个String[]数组存大王、小王 ​ 4、用上面的数组&#xff0c;生成一副扑克牌 …

C++ 文件操作-文本文件-读取和打开文件方法详解

读文件步骤 #include <iostream> using namespace std; #include <fstream> #include <string> //文本文件 读文件void test(){// 1 包含头文件// 2 创建流对象ifstream ifs;// 3 打开文件 并且判断是否打开成功ifs.open("table.txt",ios::in); //…

VS 2015 发布 WebService

本文介绍了使用VS2015发布WebService的步骤 右键项目点击发布 选择文件系统和目标位置 配置选择Debug-Any CPU&#xff08;选其他也可以&#xff09; 4. 点击发布&#xff0c;在对应文件夹中可以看到发布出来的内容。 记录遇到的问题&#xff0c; 发布前要选择删除所有现有文…