P8679 [蓝桥杯 2019 省 B] 填空问题 题解

题目传送门

欢迎大家指出错误并联系这个蒟蒻

更新日志

  • 2023-05-25 21:02 文章完成
  • 2023-05-27 11:34 文章通过审核
  • 2023-06-20 21:03 优化了文章代码格式

试题 A :组队

【解析】

本题是一道经典的 DFS 搜索题,每次对各号位的选手进行 DFS,找到各号位上有成绩的选手时再进行进一步搜索即可。

【程序】

#include <bits/stdc++.h>

using namespace std;

int team[20][6];
int max_sum;
bool vis[20]; void dfs(int u, int sum) {
if (u > 5) {
max_sum = max(max_sum, sum);
return;
}
for (int i = 0; i < 20; i++) {
if (!vis[i]) {
vis[i] = true;
dfs(u + 1, sum + team[i][u]);
vis[i] = false;
}
}
} int main() {
freopen("team.txt", "r", stdin);
for (int i = 0; i < 20; i++) {
for (int j = 0; j < 6; j++) {
cin >> team[i][j];
}
}
dfs(1, 0);
cout << max_sum;
return 0;
}

【答案】

490

试题 B :年号字串

【解析】

该题的 A~Z 相当于二十六进制的 \(26\) 个基,因此本题就转换成将 \(2019\) 转成二十六进制数的问题。

【程序】

#include <bits/stdc++.h>

using namespace std;

char ch[26];
char ans[5];
int a, n = 2019; int main() {
for (int i = 0; i < 26; i++) {
ch[i] = 'A' + i;
}
while (n) {
int t = n % 26;
n = n / 26;
if (t == 0) {
t += 26;
}
ans[a++] = ch[t - 1];
}
for (int i = a - 1; i >= 0; i--) {
printf("%c", ans[i]);
}
return 0;
}

【答案】

BYQ

试题 C :数列求值

【解析】

该数列其实很容易让人联想到斐波那契数列,可以采用计算斐波那契数列的递推法进行计算。

【程序】

#include <bits/stdc++.h>

using namespace std;

int dp[20190324];

int main() {
int i;
dp[0] = dp[1] = dp[2] = 1;
for (i = 3; i < 20190324; i++) {
dp[i] = (dp[i - 1] + dp[i - 2] + dp[i - 3]) % 10000;
}
printf("%d", dp[i - 1]);
return 0;
}

【答案】

4659

试题 D :数的分解

【解析】

本题可以枚举 \(3\) 个数字,但是如果 \(3\) 个数字都从 \(1\) 枚举到 \(2019\),则程序就会变得很复杂,我们应该主要解决以下 \(2\) 个问题:

1、三数之和等于 \(2019\)。

2、解决重复情况。

对于情况 \(1\),要满足 \(i+j+k=2019\),其实 \(i\) 和 \(j\) 一旦确定,\(k\) 的值就已经确定了,所以利用该式,定义的 \(3\) 个变量可以变成 \(i\)、\(j\)、\(2019-i-j\)。

对于情况 \(2\),要想使得 \(3\) 个数字不重复,则只需要将这 \(3\) 个数排序,保证排序后的序列是唯一的即可。

【程序】

#include <bits/stdc++.h>

using namespace std;

int judge(int a) {
while (a != 0) {
int t = a % 10;
if (t == 2 || t == 4) {
return 0;
}
a = a / 10;
}
return 1;
} int main() {
int sum = 0;
for (int i = 1; i < 2019 / 3 + 1; i++) {
if (judge(i)) {
for (int j = i + 1; j < 2019 - i - j; j++) {
if (judge(j)) {
if (judge(2019 - i - j)) {
sum++;
}
}
}
}
}
printf("%d", sum);
return 0;
}

【答案】

40785

试题 E :迷宫

【解析】

本题求步数最少的迷宫路径,即求最短路线。利用 DFS 搜索时回溯较多,容易“爆栈”,所以本题使用 BFS 求最优解即可。

【答案】

DDDDRRURRRRRRDRRRRDDDLDDRDDDDDDDDDDDDRDDRRRURRUURRDDDDRDRRRRRRDRRURRDDDRRRRUURUUUUUUULULLUUUURRRRUULLLUUUULLUUULUURRURRURURRRDDRRRRRDDRRDDLLLDDRRDDRDDLDDDLLDDLLLDLDDDLDDRRRRRRRRRDDDDDDRR

P8679 [蓝桥杯 2019 省 B] 填空问题 题解的更多相关文章

  1. 2018年蓝桥杯A组C/C++决赛题解

    2018年第九届蓝桥杯A组C/C++决赛题解 点击查看视频题解 点击查看2018年蓝桥杯A组C/C++决赛题目(不含答案) 1:三角形面积 画个图,求三角形面积,可以用外接长方形 - 其他多余区域面积 ...

  2. 2016年蓝桥杯B组C/C++决赛题解

    2016年第七届蓝桥杯B组C/C++决赛题解 2016年蓝桥杯B组C/C++决赛题目(不含答案) 1.一步之遥 枚举解方程,或者套模板解线性方程 #include<bits/stdc++.h&g ...

  3. 2015年蓝桥杯B组C/C++决赛题解

    2015年第六届蓝桥杯B组C/C++决赛题解 点击查看2015年第六届蓝桥杯B组C/C++国赛题目(不含答案)     1.积分之迷 三重循环 枚举A,B,C的值,如果满足两个条件:3个A + 7个B ...

  4. 2018年蓝桥杯B组C/C++决赛题解

    2018年第九届蓝桥杯B组C/C++决赛题解 点击查看2018年蓝桥杯B组C/C++决赛题目(不含答案) 1.换零钞 ok 枚举 设x表示1元钱的个数,y表示2元钱的个数,z表示5元钱的个数 x+21 ...

  5. 第十届蓝桥杯2019年C/C++ 大学B组省赛试题

    2019年第十届蓝桥杯大赛软件类省赛C/C++大学B组 试题 A:组队 本题总分:5分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1号位至 5号位各一名球员, 组成球队的首发阵容. 每位球 ...

  6. 第十届蓝桥杯2019年C/C++ 大学A组省赛试题

    2019年蓝桥杯第十届软件类省赛 C/C++ 大 学 A 组 试题 A: 平方和 本题总分:5 分 [问题描述] 小明对数位中含有 2.0.1.9 的数字很感兴趣,在 1 到 40 中这样的数包括 1 ...

  7. 第十届蓝桥杯省赛JavaB组个人题解

    前言 以下的第十届蓝桥杯Java B组省赛的题目题解只是我个人的题解,提供一些解题思路,仅作参考,如有错误,望大家指出,不甚感激,我会及时更改. 试题 A: 组队 ----- 答案:490 [问题描述 ...

  8. 2017年蓝桥杯B组C/C++决赛题解

    2017年蓝桥杯B组C/C++决赛题目(不含答案) 1.36进制 ok 求36进制,类比二进制转10进制,36^3 + 36^2 + 36^1 + 36^0 2.磁砖样式 ok dfs搜索 我自己写的 ...

  9. 今日学习——蓝桥杯 2019年 C语言 B组

    1.手淦(亲身体验,,,没啥大用,最终还是代码) 2.代码(下面是我看其他博主代码答案能看的懂的....具体的可以直接去下面的网址看) https://blog.csdn.net/qq_4452491 ...

  10. 第九届蓝桥杯(A组填空题)

    1.标题:分数 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + …. 每项是前一项的一半,如果一共有20项, 求这个和是多少,结果用分数表示出来. 类似: 3/2 当然,这只是加了前2项 ...

随机推荐

  1. 性能优化之window.onload

    前言 最近在做一些性能优化相关的工作,相信大家在工作过程中也会遇到一些性能优化相关的场景,这对于前端开发者来讲是一项加分技能.为了我们的用户在使用我们的产品时能够有一个非常好的体验,我们需要对页面进行 ...

  2. playwright(十三) - PyTest基本使用

      我们都知道,在做单元测试框架中有UnitTest和Pytest,前者是Python中自带无需安装,Pytest需要安装,今天我们来讲的就是Pytest,当然如果是做自动化,建议两个都要掌握一下,可 ...

  3. Valine评论插件因为LeanCloud国内域名解析问题无法正常使用的解决方法

    近日,LeanCloud 国内域名解析存在问题,Valine评论插件的评论内容都储存在LeanCloud,使用Valine评论插件的个人博客的评论及阅读数会显示失败. 关于 LeanCloud 国内域 ...

  4. [HUBUCTF 2022 新生赛]simple_RE

    [HUBUCTF 2022 新生赛]simple_RE 查壳,64位 找main函数,F5查看伪代码,简单分析一下 int __cdecl main(int argc, const char **ar ...

  5. kali下对压缩包的压缩与解压(转)

    kali linux 压缩文件解压缩命令(包含7z) tar tar 解包:tar xvf FileName.tar 打包:tar cvf FileName.tar DirName (注:tar是打包 ...

  6. HTTP&HTTPS协议

    HTTP协议 1.什么是HTTP 超文本传输协议( HyperText Transfer Protoco,缩写:HTTP)是一种用于分布式.协作式和超媒体信息系统的应用层协议. HTTP(HyperT ...

  7. 【go语言】1.2.1 Go 环境安装

    Go 语言的安装过程非常简单,无论你使用的是哪种操作系统,都可以按照下面的步骤来进行. Windows 系统 前往 Go 语言的官方下载页面:https://golang.org/dl/ 根据你的操作 ...

  8. Linux 命令:lsof

    参考文档:lsof命令详解 lsof,列出系统中所有打开的文件. 各列字段意义如下: COMMAND: 进程的名称 PID: 进程标识符 USER: 进程所有者 FD: 文件描述符,应用程序通过文件描 ...

  9. NOIP2022 题解

    终于有机会补NOIP的题了 T1 考虑枚举 C 与 F 的纵列 考虑预处理出每个点最左边和最下边可以延伸到哪 之后枚举列,然后对行做类似于扫描线的操作,统计有多少可行的 "第一横行" ...

  10. Dokcer学习之旅(2)——Dockerfile基础应用

    什么是Dockerfile? 从docker commit 的学习中,我们可以了解到,镜像的定制实际上就是定制每一层所添加的配置.文件.如果我们可以把每一层修改.安装.构建.操作的命令都写入一个脚本, ...