蓝桥杯介绍¶
一、蓝桥杯介绍¶
蓝桥杯是工信部组织的一项面向在校大学生的程序设计竟赛,分为软件组和电子组。
其中,软件组分为 C/C++组和 Java组,电子组分为嵌入式组和单片机组。
二、蓝桥杯赛制¶
竞赛分为两个阶段:初赛(省赛) 和决赛。初赛时长4个小时,一共两个方向共计6个组别同时比赛。决赛时长也为4小时,分为上午和下午两个场次。
竞赛形式为个人赛,每个人一台电脑,全程使用电脑进行答题,不能访问互联网,也不能使用 USB 等电子设备,只能访问所在考场的局域网。但是可以使用电脑的所有功能:excel、ppt、记事本、计算器。
在比赛期间会通过局域网将试题发放到你的电脑里,你需要完成题目并通过网络提交答案。
每场比赛的题型有三类:结果填空题、代码填空题和编程大题。所有题目都是客观题,以选手提交答案的评测结果为评分依据。
判题过程几乎都由机器完成,只有编程大题会有少量的人工参与(需要对代码风格和可读性进行评判,只占题目里很少的分数)。
三、题目类型¶
1、结果填空题¶
结果填空题是一类具有确定解的问题,要求你填入正确的答案。
无须写出解题过程,不限定计算的过程,你可以通过编程、在纸上计算、甚至用excel 和 Windows 自带的计算器算出答案,只要最终答案正确就能得到满分,否则得0分。
答案确保唯一性,如果你填入的格式和比赛要求的不一样也会被判为0分。
2、代码填空题¶
代码填空题描述了一个具有确定解的题目,并给出了该问题的某一解法的代码,其中会空缺一部分,需要读懂代码的逻辑,并对其中的空缺部分补充代码,使整段代码完整。
可能有多种正确答案,比如p[i]
、*(p+i)
,只要填入的代码是正确的,验证程序都会认为答案正确。
3、编程大题¶
编程大题具有一定难度梯度、分值不等的编程题目。这些题目的要求明确、答案客观。程序必须使用标准输入、标准输出(cin、cout、scanf、printf),以便于机器评卷时重定向。不要输出没有要求的、多余的内容,例如:“请您输入xx数据:”
判题规则:将标准输入和输出重定向到文件,用文件输入并输出到文件中,将输出文件与标准答案进行文本比对。
要求选手通过编程,对给定的标准输入求解,并通过标准输出,按题目要求的格式输出解。题目一般会给出示例数据。
题目的考察点一般集中于对算法的设计和逻辑的组织上。理论上,选手不可能通过猜测或其它非编程的手段获得问题的解。选手给出的解法应具有普遍性,不能只适用于题目的示例数据(当然,至少应该适用于题目的示例数据)。
为了测试选手给出解法的性能,评分时用的测试用例可能包含大数据量的压力测试用例,选手选择算法时要尽可能考虑可行性的问题。
四、注意事项¶
1、c/c++¶
主函数结尾必须return 0
。
代码中允许使用 STL
类库。
所有依赖的函数必须明确地在源文件中 #include <xxx>
,不能通过工程设置而省略常用头文件。
万能头文件:
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。提交时,注意选择所期望的编译器类型。
2、Java¶
不要使用 package
语句。
主类名必须为:Main
五、复杂度¶
算法的复杂度是评估算法性能优劣一个重要的指标,可以帮助估算出算法在执行之后所需要的时间和空间,所以分析算法的复杂度几乎成了每个选手必须掌握的能力。
在竞赛中,我们认为计算机一秒能执行 \(5*10^8\) 次计算,如果题目给出的时间限制为1s,那么你选择的算法执行的计算次数最多应该在 \(10^8\) 量级才有可能解决这个题目。
时间复杂度 | 数据范围 |
---|---|
O(n) | n ≤ 10^8 |
O(nlogn) | n ≤ 10^6 |
O(n√n) | n ≤ 10^5 |
O(n^2) | n ≤ 5000 |
O(n^3) | n ≤ 300 |
O(2^n) | n ≤ 25 |
O(n!) | n ≤ 11 |
六、代码¶
1、循环节长度¶
/**
* 循环节长度
* @author 王铭颢
* @Date 2022/11/20 13:37
*/
/*
* 除法是在余数后面不断补零的过程直到除尽
* 而小数就是余数除以除数产生的,所以小数位的循环等价于余数的循环
* (理论上最长的循环节的长度=分母的大小-1)
*
* 这里为什么用余数来判断呢?
* -- 因为小数可能会出现数字重复但不是循环节的情况,而当余数一样的时候,
* -- 其操作仍是余数除以除数,所以可以判断是已经进入循环的!!!
*/
#include "iostream"
#include "vector"
#include "algorithm"
using namespace std;
int f(int n, int m) {
n = n % m;
vector<int> v;
for (;;) {
v.push_back(n);
n *= 10;
n = n % m;
if (n == 0) return 0;
if (find(v.begin(), v.end(), n) != v.end())
// find(...)查找失败返回end()迭代器
{
return (int) (v.end() - find(v.begin(), v.end(), n));
}
}
}
int main() {
int m, n;
cin >> n >> m;
cout << f(n, m) << endl;
return 0;
}
2、最大公约数¶
辗转相除法法:两数相除,取余数重复进行相除,直到余数为0时,前一个除数即为最大公约数