推广 热搜: 公司  快速  上海  中国  未来    企业  政策  教师  系统 

蓝桥杯重点(C/C++)(随时更新,更新时间:2023.1.27)

   日期:2024-10-04       caijiyuan   评论:0    移动:http://zhiwen.bhha.com.cn/news/9664.html
核心提示:点关注不迷路,欢迎推荐给更多人 目录 1? 技巧 1.1? 取消同步(节约时间,甚至能多骗点分,最好每个程

点关注不迷路,欢迎推荐给更多人

目录

1? 技巧

1.1? 取消同步(节约时间,甚至能多骗点分,最好每个程序都写上

1.2? 万能库(可能会耽误编译时间,但是省脑子

1.3? 蓝桥杯return 0千万别忘了写

1.4? 编译设置(Dev C++

1.5? memset填充函数

1.6? 时间复杂度

1.6.1? 常数阶? O(1

1.6.2? 对数阶? O(logn

1.6.3? 线性阶? O(n

1.6.4? 线性对数阶? O(nlogn)

1.6.5? 多重循环? O(n^k

1.7? 剪枝

1.8? find函数

1.9 PI问题

1.10? C/C++帮助文档

2? 基本算法及技巧

2.1? BFS(宽度优先搜索

2.2? DFS(深度优先搜索

2.3? 最大公约数和最小公倍数

2.4? 进制转换+超大数据处理

2.4.1? 十进制为媒介(常用型

2.4.2? 二进制为媒介(技巧型(含超大数据处理

2.5? 二进制表示法

2.6? 背包问题

2.6.1? 01背包问题

2.6.2? 多重背包问题(每种物品有多件

2.6.3? 完全背包问题(每种物品有无数件

2.7? 动态规划(DP

2.8? 贪心

2.9? 分治(以后更新

2.10? 数字分拆到数组中

2.11? 数字和字符串的互化

2.12? 排序

2.13? 冒泡排序法和二分查找法(最常用

2.14? 图论

2.15? 常用树

2.16? 二次幂算法

3? STL

3.1? 队列(queue

3.2? 链表(list)?

?3.3? 优先队列(priority queue

3.4? 向量/动态数组(vector

?3.5? 栈(stack

3.6? 集合(set)?(要求没有重复元素

?3.7? 集合/映射/键值对(map

3.8? 迭代器


 
 
 
 
 

(1)工具->编译选项->编译器->编译时加入以下命令->调成C99

?(2)工具->编译选项->代码生成/优化->代码生成->语言标准

按照字节对内存块进行初始化,注意只能填充0或-1

 
 

蓝桥杯每一道题编译时间都限制在1s以内,遇到数据比较大的题目,往往需要降低时间复杂度。

粗略估计,O(n)情况下一秒大概完成4亿次,O(n*n)情况下一秒大概完成2万次,O(n*n*n)情况下大概完成700次。

由于蓝桥杯评测系统是根据通过样例数来评分,所以我们做题时一定要注意约定样例取值范围。

例题:K倍区间(暴力法只能通过部分样例,所以要用更好的算法

 
 
 
 
 
 
 
 

k为循环层数

做题时已经发现的不可能取到的数值,就不要再让计算机算了,尽量节省时间,蓝桥杯中目前遇到的还没有用到过过于繁琐的剪枝,大多也是在BFS和DFS中出现(bool vis)

函数作用:查找该元素在数组中第一次出现的位置的地址(类似于0x的地址

模型:find(查找起点,查找终点,查找目标元素

同样,查找区间为[查找起点,查找终点

 
 

PI=atan(1.0)*4

用到队列(有时会用到优先队列

主要思想:把所有符合条件的点都压入队列,然后挨个元素弹出上下左右前后搜索,直到队列清空时代表搜索完毕,搜索的时候注意判断是否已经搜索过,用bool vis【】判断。

例题:全球变暖

用到递归(不好理解

主要模板:可参见如下全排列例题

http://t.csdn.cn/ANnS1

总结起来有如下几步

(1)确定 边界? ? if)return

(2)进入for循环

(3)判断是否搜索过? if(vis[])vis[]=true; dfs();? vis[]=false;

例题1:凑算式

例题2:2n皇后问题

最大公约数(greatest common divisor,gcd

 

最小公倍数 (least common multiple,lcm

多写一个lcm函数

 
 
 

例题:无聊的逗

 
 

把多件物品捏合成一件新的物品,按序号往后叠加即可

 
 

例题1:拿金币

例题2:包子凑数

思路:选取局部最优解,但是最大的缺陷就是在某些情况下不适用

举例:纸币问题

比如面额有1元,2元,5元,10元,20元,50元,100元,那么对于110元来说,可以用贪心从最大面额100元开始找。

但是如果改纸币面额,比如1元,2元,5元,20元,55元,100元,那么如果用到贪心算法,会发现并不能找出最优解(贪心:100+5+5=110? 动态规划:55+55=110

动态规划代码如下

 
 

大部分是二分法

求不了子数字,但能求子字符串

例题:超级质数

?优先队列默认大根堆(大到小排序,如果想从小到大排序,那么

<int,vector<int>,greater<int> >//升序排列(小根堆

<int,vector<int>,less<int> >//降序排列(大根堆

set<int> s;//默认升序排列

set<int, greater<int>> ?s2 = {3,2,5,1,4 ,3};//降序

set值不能修改(修改过后无法保证数据顺序

?模板

 

这里大概列出参加蓝桥杯需要掌握的知识点和技巧,若想详细了解某个知识点,可以看看我的例题和别人的文章

本文地址:http://zhiuk.bhha.com.cn/news/9664.html    康宝晨 http://zhiuk.bhha.com.cn/ , 查看更多
 
 
更多>同类行业资讯
0相关评论

新闻列表
企业新闻
推荐企业新闻
推荐图文
推荐行业资讯
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  粤ICP备2023022329号