[题解] 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 相当于二十六进制的
【程序】
#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:数的分解
【解析】
本题可以枚举
1、三数之和等于
2、解决重复情况。
对于情况
对于情况
【程序】
#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 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步