ACM 训练大纲【CSUST_ACM】

本文提供了ACM竞赛训练所需的算法、数据结构、题库及书籍推荐。覆盖从基础到高级的各种算法,如贪心、图论、动态规划等,并推荐多个在线题库供练习。

                        来源:彪神发的训练文档                                 
                                                                     ACM 训练大纲
                                                                                                 
                          Changsha University of Science & Technology
                                                                                                                       
                                                    July 31, 2012
                                                                                                                                                

 1 推荐题库


http://ace.delos.com/usaco/
美国的OI 题库,如果是刚入门的新手,可以尝试先把它刷通,能够学到几乎全部的基础算法极其优化,

全部的题解及标程还有题目翻译可以baidu 一个叫NOCOW 的网站。


http://livearchive.onlinejudge.org/

上面有全部的赛区真题,绝大部分都可以提交,不适合当题库刷,不过在这里找题非常方便。


• http://poj.org/

不解释了,中国最知名的oj,题量非常之大,历史也很悠久,推荐刷一些代表性的题目。


http://acm.timus.ru/
Ural 大学的oj,国外oj 中非常好的一个,题目非常锻炼基本功,管理员会不时添加一些新数据rejudge,

推荐找些通过人数适中的题目割一割。


• http://acm.sgu.ru/

SGU 大学的oj,题目比较经典(比较老,几百年不更新了),不是特别推荐。


• http://www.spoj.pl
比较奇葩的一个oj,有一些与众不同的提交模式,也有很多著名的系列题目,qtree 等,题目质量很好,

但问题是国内的题解较少,新手如果只是想去割水题还是不要去了。


http://acm.hdu.edu.cn
航电大学的oj,亮点是上面独有的中国多校联合训练的题目,而且有一版(貌似是20 开头的那版)水题

大全,新手提高很不错。


• http://acm.zju.edu.cn

每个月定时有月赛,浙大出题非常靠谱,推荐每个月月赛可以做一做。


• http://acm.hust.edu.cn
华中科技大学的oj,也就是各大oj 著名的virtual judge(三国五虎上将)的始作俑者,亮点就是那个模

拟比赛的功能异常好用,平时大家可以自己配题做做模拟比赛。


• http://www.codeforces.com
著名线上比赛网站,几乎每周都有一场线上比赛,有各国牛人参加,强烈推荐按时参加提高实力(要克

服时差问题)。


• http://www.topcoder.com/tc
更著名的一个线上比赛网站,历史相当悠久,而且有丰富的奖金,强烈推荐去做algorithm 比赛的single

round match,非常提高智商。


2 算法总结及推荐题目



2.1 C++ STL


• STL 容器: set, map, vector, priority_queue, queue, stack, deque, bitset
• STL 算法: sort, unique, nth_element, reverse, rotate, next_permution, find, for_each, count, lower_bound,

max, swap, random_shuffle


2.2 基本算法


• 枚举: poj1753, poj2965, zoj1716, zoj3356, ural1010
• 贪心: poj1328, poj2109, poj2586, ural1303, sgu195, sgu171
• 递归与分治: ural1181, poj1579, poj1845, poj3714
• 构造: poj3922, poj1092, sgu121
• 模拟: poj3125, poj1068, poj2993, ural1007
• 排序: ural1082, poj2092, poj1694
• KMP 算法: poj2406
• 扩展KMP: poj3376, poj1699
• 二分法: poj1905, poj2002
• 三分法: hdu3400, hdu2298
• 矩阵乘法: zoj2105, zoj3289
• 离散化: ural1019, sgu177
• 快速傅立叶变换: poj2821

• 环状字符串最小表示: poj1509


2.3 图论


• 深度优先遍历: poj2488
• 宽度优先遍历: poj3620, poj2251
• 最短路: poj1847, poj1062
• 最小生成树: zoj1914
• 拓扑排序: zoj2193, zoj1060
• 二分图最大匹配: poj1469
• 二分图的最大权匹配: ural1076
• 稳定婚配问题: poj3487
• 最大流与最小割: poj1459
• 带下界的最大流: poj2396
• 最小费用最大流: poj2159
• 差分约束系统: poj1275
• 双连通分量: zoj2588
• 强连通分量: zoj2470, poj2186
• 割边及割点: poj3352, poj3177
• 度限制生成树: poj1638, hdu3070
• K 短路: poj2449, sgu145
• 最近公共祖先: poj1330
• 最优比率生成树: poj2728
• 次小生成树: poj1679
• 最小树形图: poj3164
• 欧拉回路与路径: poj1386, poj2337
• 哈密顿回路: sgu122
• 旅行商问题: poj2288
• 极大团搜索: poj2989
• 弦图的判定与应用: zoj1015

• 任意图的最大匹配: ural1099


2.4 数据结构


• 栈与队列: poj2559
• 并查集: poj1611, poj1182
• 哈希表: poj1840, poj1186
• 优先队列: poj1862, poj3253
• 可合并堆: zoj2334
• 字母树及AC 自动机: zoj3430, zoj3228
• 线段树: zoj3317, zoj1610
• 树状数组: poj2299, poj2352
• 倍增表(RMQ): poj3368, poj2452
• 平衡二叉树: poj2892, poj2418, poj3580
• 后缀数组: poj2774, poj3294
• KD 树: spoj2835, poj2528
• 树链剖分: poj3237, spoj2666, spoj2798
• 树的分治算法: poj2114, poj1987

• 动态树: hdu2475, hdu3601, hdu4010


2.5 搜索


• 简单技巧与剪枝: poj1033, poj3009
• 最优化与可行性剪枝: poj1011, poj1190
• 记忆化搜索: poj1191, poj1088
• 迭代加深: poj2286, poj2032
• A 搜索: hdu2467, poj1077
• Dancing Link: poj3074, hdu4069
• 折半搜索: zoj3631
• 双向广搜: poj1198, poj1915


2.6 动态规划


• 资源分配问题: poj3624, poj2063
• 区间划分问题: poj3280
• 状态压缩问题: poj1185
• 树形DP: poj1463, poj3345
• 数据结构优化DP: poj2374, poj2355
• 四边形不等式: poj1160
• 队列优化: zoj3399
• 插头表示的状态压缩DP: poj1739
• 最小表示法的状态压缩DP: spoj2159

• 数位DP: hdu3555, sgu258, sgu390


2.7 数学


• 排列组合: poj1850, poj3252
• Lucas 定理: poj3219
• 素数测试与筛法: poj2191, poj1811
• 大数分解的快速算法: poj1142
• 进位制: poj2798, poj1702
• 同余模运算: poj1006, poj2115
• 容斥原理: poj3904, poj1173
• 置换群与Burnside 引理: poj2888
• 递推关系与母函数: poj3734
• 高斯消元: poj1681, poj1222
• 概率与统计: poj2151, poj1021
• 扩展欧几里得算法: poj2891, poj1061
• 中国剩余定理: poj1006, zoj3538
• 离散对数与离散根: sgu261
• 拉格朗日插值: uva4209
• 迭代逼近: poj2868, poj3933
• 莫比乌斯反演: poj2154
• 博弈论与SG 函数: poj2960, poj2311
• 偏序论与格: poj1065, poj3636


2.8 计算几何


• 点积与叉积: zoj1010
• 线段相交: zoj1648
• 简单多边形的面积: poj1654
• 点到线段的最近最远距离: ural1348
• 凸包: poj1113
• 对锺点: poj2187
• 圆与点的切线: poj1375
• 圆与直线的交: poj1263
• 圆与圆的交: poj2564
• 圆与多边形的并与交: poj3675
• 点在多边形内: poj2398
• 半平面交: poj1474, poj2540
• 最小圆覆盖: zoj1450, spoj145
• 三维凸包: poj3528
• 三维点与直线的表示: poj3129

• 线性规划: poj1755


3 推荐书籍


• 《Introduction to Algorithms》
著名的算法大全,囊括全部的基础算法,其详尽程度超乎想象,而且都做了不同程度的扩展,若能同时

配合做一做上面的习题,受益匪浅。


• 《算法艺术与信息学竞赛》
俗称黑书,lrj 的成名之作,非常开拓视野,推荐阅读并掌握。另外,lrj 最近出了一本白书,我没读过,

听说更加基础,有兴趣的同学可以去读一读。


• 《Concrete Mathematics》
计算机学科的必备书籍之一,该书几乎包括计算机科学用到的全部数学知识,如果感兴趣,推荐深入阅

读更专业的书籍(组合数学、初等数论、离散数学、线性代数等等)。


• 《How to solve it》
这一本与上面基本不同,讲的是怎样解题,一本可以帮助你更好地数学建模抽象问题的书籍,不光对竞

赛,对整个思维方式都有帮助。


• 《Computational Geometry Algorithms and Applications》
相当详细的一本计算几何书籍,计算几何往往是一场比赛中最考研基本功最不需要思维复杂度的题目,

练好计算几何对比赛相当有利。


• 《C++ 程序设计思想与方法》
对C++ 语言特性不熟悉的同学建议看看,很好的一本介绍C++ 语言的书籍,有余力的建议再学个

java,写大模拟题、高精度题都有巨大优势。


• 全部的NOI 国家集训队作业以及论文
在网上全部可以找到,非常好的资料,都是历年的强手将当时最先进的知识整理所得,也包括不少题库
的题解。

在理解或优化ACMP(Analog Comparator,模拟比较器)通道配置函数的实现时,需要从硬件寄存器配置、输入源选择、输出极性控制、中断设置等多个维度进行解析。ACMP通常用于比较两个模拟电压信号,并根据比较结果触发相应的数字输出或中断响应。其配置函数通常用于嵌入式系统中,例如基于ARM Cortex-M系列MCU的开发。 ### ACMP通道配置函数的核心实现要素 1. **通道选择与初始化** ACMP模块通常支持多个通道,每个通道可以独立配置。初始化时需要选择对应的通道号,并将其映射到特定的GPIO引脚。例如,在某些MCU中,ACMP通道可以通过寄存器 `ACMPx_CTRL` 进行使能和通道选择。 2. **输入源配置** 模拟比较器的两个输入端(正输入和负输入)可以选择不同的信号源,如外部引脚、内部参考电压或DAC输出。例如: - 正输入可选择为外部引脚 `ACMPx_POSSEL` - 负输入可选择为内部参考电压 `ACMPx_NEGSEL_VREF` 通过配置这些寄存器字段,可以灵活地定义比较器的输入信号源[^1]。 3. **输出极性与滤波设置** 输出极性决定了比较器输出的高/低电平对应关系。此外,为了防止噪声引起的误触发,通常支持输出滤波功能。例如: - 设置输出极性反转 `ACMPx_CTRL_INVERT` - 启用输出滤波 `ACMPx_CTRL_FILTER` 4. **中断与事件触发配置** 比较器可以配置为在输出状态变化时触发中断或DMA事件。例如: - 使能上升沿中断 `ACMPx_IER_CFR` - 使能下降沿中断 `ACMPx_IER_CFF` 这些设置通常通过中断使能寄存器 `ACMPx_IER` 进行配置,同时需要在NVIC中启用相应的中断向量。 5. **电源与功耗控制** 在低功耗应用中,可以通过配置比较器的工作模式(如高速模式、低功耗模式)来平衡响应速度与功耗。例如: - 设置为低功耗模式 `ACMPx_CTRL_MODE_LP` 这类配置通常通过 `ACMPx_CTRL` 寄存器中的模式位进行控制[^1]。 ### 示例代码:ACMP通道配置函数 以下是一个典型的ACMP通道配置函数的伪代码示例,假设使用的是基于ARM Cortex-M架构的MCU: ```c void ACMP_Channel_Config(uint8_t channel, uint8_t pos_input, uint8_t neg_input, bool invert_output, bool enable_filter) { // 选择ACMP模块并使能时钟 ACMPx_CLOCK_ENABLE(); // 设置比较器通道 ACMPx_CTRL &= ~ACMP_CTRL_SEL_MASK; ACMPx_CTRL |= (channel << ACMP_CTRL_SEL_SHIFT); // 配置输入源 ACMPx_POSSEL = pos_input; ACMPx_NEGSEL = neg_input; // 设置输出极性 if (invert_output) { ACMPx_CTRL |= ACMP_CTRL_INVERT; } else { ACMPx_CTRL &= ~ACMP_CTRL_INVERT; } // 启用输出滤波 if (enable_filter) { ACMPx_CTRL |= ACMP_CTRL_FILTER; } else { ACMPx_CTRL &= ~ACMP_CTRL_FILTER; } // 启用比较器 ACMPx_CTRL |= ACMP_CTRL_ENABLE; } ``` ### 优化建议 1. **减少寄存器操作次数** 在配置过程中,尽量减少对寄存器的多次读写操作,可以通过位域结构体或宏定义一次性设置多个字段,提高执行效率。 2. **使用预定义常量** 将输入源、滤波模式等配置参数定义为枚举或宏常量,提升代码可读性和可维护性。 3. **支持动态配置** 在运行时根据系统需求动态调整比较器参数,例如通过API接口实现输入源切换、中断使能/禁用等功能。 4. **功耗优化** 在不需要比较器工作的阶段,及时关闭其电源或切换至低功耗模式,以延长电池寿命。 5. **错误处理与状态检查** 在配置函数中加入对无效输入参数的检查,并返回相应的错误码,增强函数的健壮性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值