2019第十届蓝桥杯C\C++B组省赛赛后总结

2024-02-14 13:10

本文主要是介绍2019第十届蓝桥杯C\C++B组省赛赛后总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总结

不愧是暴力杯,今年题目基本全是暴力模拟,没有太难的算法题,不过由于蓝桥杯的赛制没有反馈机制,也就是你不能马上知道自己的答案对错,导致会因为粗心丢分。拖到现在才写博客就是因为粗心丢了好多分。。。

因为我是开一个cpp文件,作完一道题就会把代码删完然后再重新在这个文件里写,但是这样到了最后想要检查几乎是不可能的,因为之前代码都被我删了。。不过我也没有想到检查,我做完前九道差不多用了两个半小时,后面就一直看最后一题题意,丝毫不知道瞄一眼前面提交的答案。我好SA

建议可以在比赛还没开始时建十个cpp文件,这样什么时候回头看自己的代码都没问题。另外做题要慢慢看题意,有时间要检查。

2019.3.28 省二

PDF:链接:链接: https://pan.baidu.com/s/1b7ceNpa9nyN0r6Xy3VvuLg 提取码: 33i2

题解

一、组队

在这里插入图片描述
题目没什么说的,要找到5个队员让评分和最大,注意有可能选出重复的人
比赛时我连程序都没写,直接找每列最大的数字相加得492,最后GG,要是后面检查一下就好了

答案:490

二、年号子串

在这里插入图片描述
就是十进制转26进制,

#include <bits/stdc++.h>using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 1000 + 10;
const int INF = 0x3f3f3f3f;int main()
{int num = 2019;while(num){cout << char('A'+num%26-1) << endl;num /= 26;}return 0;
}

程序输出结果是Q Y B,要倒着输出答案,
答案:BYQ

三、数列求值

在这里插入图片描述
直接数组模拟,因为只需要后面4位,模10000就行

#include <bits/stdc++.h>using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 20190324 + 10;
const int INF = 0x3f3f3f3f;int a[N];
int main()
{a[1] = 1;a[2] = 1;a[3] = 1;for (int i = 4; i <= 20190324; i++){a[i] = a[i - 1] + a[i - 2] + a[i - 3];a[i] %= 10000;}cout << a[20190324] << endl;return 0;
}

答案:4659

四、数的分解

在这里插入图片描述
因为只有三个数,暴力枚举即可,
比赛时没看到三个数不相同,心酸,GG

#include <bits/stdc++.h>
using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 20190324 + 10;
const int INF = 0x3f3f3f3f;bool judge(int n){while(n>0){int t = n%10;n /= 10;if(t == 2 || t == 4)return false;}return true;
}
int main()
{int n, ans = 0;n = 2019;for(int i = 1; i <= n; i++){for(int j = i+1; j <= n && (n-i-j)>j; j++){if(judge(i) && judge(j) && judge(n-i-j))ans++;}}cout << ans << endl;return 0;
}

答案:40785

五、迷宫

在这里插入图片描述

01010101001011001001010110010110100100001000101010 
00001000100000101010010000100000001001100110100101 
01111011010010001000001101001011100011000000010000 
01000000001010100011010000101000001010101011001011 
00011111000000101000010010100010100000101100000000 
11001000110101000010101100011010011010101011110111 
00011011010101001001001010000001000101001110000000
10100000101000100110101010111110011000010000111010 
00111000001010100001100010000001000101001100001001 
11000110100001110010001001010101010101010001101000 
00010000100100000101001010101110100010101010000101 
11100100101001001000010000010101010100100100010100 
00000010000000101011001111010001100000101010100011 
10101010011100001000011000010110011110110100001000 
10101010100001101010100101000010100000111011101001 
10000000101100010000101100101101001011100000000100 
10101001000000010100100001000100000100011110101001 
00101001010101101001010100011010101101110000110101 
11001010000100001100000010100101000001000111000010 
00001000110000110101101000000100101001001000011101 
10100101000101000000001110110010110101101010100001 
00101000010000110101010000100010001001000100010101 
10100001000110010001000010101001010101011111010010 
00000100101000000110010100101001000001000000000010 
11010000001001110111001001000011101001011011101000 
00000110100010001000100000001000011101000000110011 
10101000101000100010001111100010101001010000001000 
10000010100101001010110000000100101010001011101000 
00111100001000010000000110111000000001000000001011 
10000001100111010111010001000110111010101101111000
BFS模板题,用了一个string输出路径,注意走的方向要按字典序,说起来比赛的时候还卡了20分钟bug,下面写的时候2分钟撸完了。。。
#include <bits/stdc++.h>
using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 50 + 10;
const int INF = 0x3f3f3f3f;char a[N][N];
int vis[N][N];
int dir[4][2] = {{1,0},{0,-1},{0,1},{-1,0}};
string op[4] = {"D","L","R","U"};
struct node{int x;int y;string str;node(int x, int y, string str):x(x),y(y),str(str){}
};
void bfs()
{queue<node> q;q.push(node(0, 0, ""));while(!q.empty()){node cnt = q.front();q.pop();if(cnt.x == 29 && cnt.y == 49){cout << cnt.str << endl;cout << cnt.str.length() << endl;return;}for (int i = 0; i < 4; i++){int xx = cnt.x + dir[i][0];int yy = cnt.y + dir[i][1];if(!vis[xx][yy] && a[xx][yy] != '1' && xx >= 0 && xx < 30 && yy >= 0 && yy < 50){vis[xx][yy] = 1;q.push(node(xx, yy, cnt.str + op[i]));}}}
}
int main()
{for (int i = 0; i < 30; i++){scanf("%s", a[i]);}vis[0][0] = 1;bfs();return 0;
}

答案:DDDDRRURRRRRRDRRRRDDDLDDRDDDDDDDDDDDDRDDRRRURRUURRDDDDRDRRRRRRDRRURRDDDRRRRUURUUUUUUULULLUUUURRRRUULLLUUUULLUUULUURRURRURURRRDDRRRRRDDRRDDLLLDDRRDDRDDLDDDLLDDLLLDLDDDLDDRRRRRRRRRDDDDDDRR

六、特别数的和

在这里插入图片描述
还是暴力枚举。。。

#include <bits/stdc++.h>
using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
// const int N = 50 + 10;
const int INF = 0x3f3f3f3f;int N;
bool f(int x) {for (; x > 0; x /= 10) {int t = x % 10;if (t % 10 == 2 || t % 10 == 0 || t % 10 == 1 || t % 10 == 9)return true;}return false;
}
int main() {cin >> N;int ans = 0;for (int i = 1; i <= N; ++i)if (f(i)) ans += i;cout << ans << endl;return 0;
}

七、完全二叉树的值

在这里插入图片描述
看题目还有二叉树,其实根本不用建树,直接模拟每一层即可,注意完全二叉树并不是满二叉树,如下图
在这里插入图片描述
有可能最后一行不是满的
比赛时候没有注意元素为负数,GG

#include <bits/stdc++.h>
using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 1e5 + 10;
const int INF = 0x3f3f3f3f;int num;
ll a[N];
int cnt = 0;int main() {scanf("%d", &num);int m = 1;int mm = 1;int n;while(mm <= num){int t = m;ll ans = 0;while(t--){scanf("%d", &n);ans += n;}a[cnt++] = ans;m *= 2;mm += m;}if(mm > num){int t = num - (mm-m);ll ans = 0;while(t--){scanf("%d", &n);ans += n;}a[cnt++] = ans;}int ans = 1;ll an = a[0];for (int i = 1; i < cnt; i++){if(a[i] > an){ans = i + 1;an = a[i];}}cout << ans << endl;return 0;
}

八、等差数列

在这里插入图片描述
存数组里排序,取两两之间差值分别求gcd,最后就是公差,注意特判0的情况
比赛没有特判0,GG

#include <bits/stdc++.h>
using namespace std;
#define db(x) cout << (x) << endltypedef long long ll;
const int N = 1e5 + 10;
const int INF = 0x3f3f3f3f;int n;
int a[N];
int main()
{cin >> n;for(int i = 1; i <= n; i++)cin >> a[i];sort(a+1, a+1+n);int d = a[2]-a[1];if(d==0)cout << n << endl;else{for(int i = 3; i <= n; i++)d = __gcd(d, a[i]-a[i-1]);cout << (a[n]-a[1])/d+1 << endl;;}return 0;
}

九、后缀表达式

在这里插入图片描述

十、 灵能传输

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
前九道两个半小时做完,最后一个半小时一直在看这题题意样例,对,不是想怎么做,实在看样例,实在看不懂要输出什么,神他喵的阅读理解杯,有这时间前面粗心的也能看几道了。。

最后按照自己想的规则过了两组样例就提交了,就是输出不稳定度最小的序列的最大值。

正解还不知道

这篇关于2019第十届蓝桥杯C\C++B组省赛赛后总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/708597

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码