为了能到远方,脚下的每一步都不能少.|
2024-05-17 22:40阅读: 5评论: 0推荐: 0

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

试题 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()
{
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,其实 ij 一旦确定,k 的值就已经确定了,所以利用该式,定义的 3 个变量可以变成 ij2019ij
对于情况 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

本文作者:cq_irritater

本文链接:https://www.cnblogs.com/cq-irritater/p/18198830/solution-luogu-p8679

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   cq_irritater  阅读(5)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起