深入浅出蓝桥杯:算法基础概念与实战应用(三)搜索

作者:铭哥的编程日记日期:2025/11/18

算法基础概念与实战应用(三)搜索


文章目录

  • 算法基础概念与实战应用(三)搜索
  • 1.1 深度优先搜索 - DFS
    • 1.1.1 枚举⼦集
    • 1.1.2 组合型枚举
    • 1.1.3 枚举排列
    • 1.1.4 全排列问题
  • 1.2 DFS
    • 1.2.1 选数
    • 1.2.2 ⻜机降落
  • 整体源代码总结

在这里插入图片描述


1.1 深度优先搜索 - DFS

1.1.1 枚举⼦集


在这里插入图片描述


代码如下(示例):

1#include <iostream>
2using namespace std;
3int n;
4string path; // 记录递归过程中,每⼀步的决策
5void dfs(int pos)
6{
7	if (pos > n)
8	{
9		// path 就存着前 n 个⼈的决策
10		cout << path << endl;
11		return;
12	}
13	// 不选
14	path += 'N';
15	dfs(pos + 1);
16	path.pop_back(); // 回溯,清空现场
17	// 选
18	path += 'Y';
19	dfs(pos + 1);
20	path.pop_back(); // 清空现场
21}
22int main()
23{
24	cin >> n;
25	dfs(1);
26	return 0;
27}
28

1.1.2 组合型枚举


在这里插入图片描述


代码如下(示例):

1#include <iostream>
2#include <vector>
3using namespace std;
4int n, m;
5vector<int> path;
6// path.size();
7void dfs(int begin)
8{
9	if (path.size() == m)
10	{
11		for (auto x : path) cout << x << " ";
12		cout << endl;
13		return;
14	}
15	for (int i = begin; i <= n; i++)
16	{
17		path.push_back(i);
18		dfs(i + 1);
19		path.pop_back(); // 清空现场
20	}
21}
22int main()
23{
24	cin >> n >> m;
25	dfs(1);
26	return 0;
27}
28

1.1.3 枚举排列

在这里插入图片描述


代码如下(示例):

1#include <iostream>
2#include <vector>
3using namespace std;
4const int N = 15;
5int n, k;
6vector<int> path;
7bool st[N]; // 标记⼀下哪些数已经选过了
8void dfs()
9{
10	if (path.size() == k)
11	{
12		for (auto x : path) cout << x << " ";
13		cout << endl;
14		return;
15	}
16	for (int i = 1; i <= n; i++)
17	{
18		if (st[i]) continue;
19		path.push_back(i);
20		st[i] = true;
21		dfs();
22		// 恢复现场
23		path.pop_back();
24		st[i] = false;
25	}
26}
27int main()
28{
29	cin >> n >> k;
30	dfs();
31	return 0;
32}
33

1.1.4 全排列问题


在这里插入图片描述


代码如下(示例):

1#include <iostream>
2#include <vector>
3using namespace std;
4const int N = 15;
5int n;
6bool st[N];
7vector<int> path;
8void dfs()
9{
10	if (path.size() == n)
11	{
12		for (auto x : path)
13		{
14			printf("%5d", x);
15		}
16		cout << endl;
17		return;
18	}
19	for (int i = 1; i <= n; i++)
20	{
21		if (st[i]) continue;
22		path.push_back(i);
23		st[i] = true;
24		dfs();
25		// 恢复现场
26		path.pop_back();
27		st[i] = false;
28	}
29}
30int main()
31{
32	cin >> n;
33	dfs();
34	return 0;
35}
36

1.2 DFS

1.2.1 选数

在这里插入图片描述


代码如下(示例):

1
2#include<iostream>
3using namespace std;
4const int N = 25;
5int n, k;
6int a[N];
7int ret;
8int path; // 记录路径中所选择的数的和
9bool isprime(int x)
10{
11	if (x <= 1) return false;
12	// 试除法
13	for (int i = 2; i <= x / i; i++)
14	{
15		if (x % i == 0) return false;
16	}
17	return true;
18}
19void dfs(int pos, int begin)
20{
21	if (pos > k)
22	{
23		if (isprime(path)) ret++;
24		return;
25	}
26	for (int i = begin; i <= n; i++)
27	{
28		path += a[i];
29		dfs(pos + 1, i + 1);
30		path -= a[i]; // 恢复现场
31	}
32}
33int main()
34{
35	cin >> n >> k;
36	for (int i = 1; i <= n; i++) cin >> a[i];
37	dfs(1, 1);
38	cout << ret << endl;
39	return 0;
40}
41

1.2.2 ⻜机降落

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述


代码如下(示例):

1#include <iostream>
2#include <cstring>
3using namespace std;
4const int N = 15;
5int n;
6int t[N], d[N], l[N];
7bool st[N]; // 标记路径中哪些⻜机已经摆放过
8bool dfs(int pos, int end)
9{
10	if (pos > n)
11	{
12		return true;
13	}
14	for (int i = 1; i <= n; i++)
15	{
16		if (st[i] == true) continue; // 剪枝
17		if (end > t[i] + d[i]) continue; // 剪枝
18		int newend = max(t[i], end) + l[i];
19		st[i] = true;
20		if (dfs(pos + 1, newend)) return true;
21		st[i] = false; // 回复现场
22	}
23	return false;
24}
25int main()
26{
27	int T; cin >> T;
28	while (T--) // 多组测试数据的时候,⼀定要注意清空数据
29	{
30		memset(st, 0, sizeof st);
31		cin >> n;
32		for (int i = 1; i <= n; i++) cin >> t[i] >> d[i] >> l[i];
33		if (dfs(1, 0)) cout << "YES" << endl;
34		else cout << "NO" << endl;
35	}
36	return 0;
37}
38



代码如下(示例):

``


整体源代码总结

代码如下(示例):

``


深入浅出蓝桥杯:算法基础概念与实战应用(三)搜索》 是转载文章,点击查看原文


相关推荐


Snapchat 开源全新跨平台框架 Valdi ,一起来搞懂它究竟有什么特别之处
恋猫de小郭2025/11/17

最近看到好几篇在推 Valdi 的文章,大致意思就是 「RN/Flutter 的地位将受到威胁」,「Valdi 将成为全新的跨平台流行架构」云云,这不仅就让我好奇这个新框架有什么魔力,还能在 2025 的跨平台领域玩出新花样? 首先,Valdi 是由 Snapchat 开源的跨平台框架,其核心技术已在 Snap 的生产应用中验证长达 8 年,号称在不牺牲开发速度的前提下提供原生性能 ,那它是怎么做到的? 简单来说,Valdi 是一个 “用 TypeScript(TSX)写 UI,然后编


Java游戏高级编程 | 深入探索游戏引擎与优化技巧
mfnart_2822025/11/15

在线编译C语言|探索在线编译器的优势与应用在线编译C语言是一项非常实用的技术,它使得程序员能够在没有本地开发环境的情况下直接在浏览器中编写、调试和执行C语言代码。在线编译器通过提供一个即时反馈的开发环境,大大提高了学习和工作的效率,尤其对于初学者而言,更是降低了编程的门槛。相比传统的桌面编译器,在线编译器的优势在于其便捷性和灵活性。用户不需要安装任何开发工具,只需在浏览器中输入代码,点击“编译”按钮,就可以立即看到运行结果。这种即时性大大减少了开发中的等待时间,尤其是在调试阶段,可以快速查看修改


前端图形引擎架构设计:双引擎架构设计
猪猪拆迁队2025/11/14

ECS渲染引擎架构文档 写在前面 之前写过一篇ECS文章,为什么还要再写一个,本质上因为之前的文档,截止到目前来说,变化巨大,底层已经改了很多很多,所以有必要把一些内容拎出来单独去说。 由于字体文件较大,加载时间会比较久😞 另外如果有性能问题,我会及时修复,引擎改造时间太仓促,只要不是内存泄漏,暂时没去处理。 还有很多东西要做。 体验地址:baiyuze.github.io/design/#/ca… 项目概览 Duck-Core 是一个基于 ECS(Entity-Component-Sy


GPT-5.1 凌晨突袭,奥特曼听劝!全网呼唤的人味回来了
新智元2025/11/13

「【新智元导读】今天,OpenAI GPT-5.1「全家桶」突然登场,Instant 和 Thinking 王炸组合同步上线。这一次,模型情商智商双核升级,不仅更聪明,而且聊天更有人味了。」 没有直播,OpenAI 一早放大招,让所有人猝不及防。 就在刚刚,GPT-5.1 正式发布,GPT-5 系列重大升级版登场! 一共有三个版本,目前已经上线了前两个: · GPT-5.1 Instant :最常用的模型,语气更亲切、更智能,更善于遵循指令。 · GPT-5.1 Thinking :先进的推理模


李飞飞最新长文:AI的下一个十年——构建真正具备空间智能的机器
机器之心2025/11/11

就在昨晚,关于其投身的空间智能,斯坦福大学教授李飞飞发表了一篇长篇博客《From Words to Worlds: Spatial Intelligence is AI’s Next Frontier》。 在文中,李飞飞详细解读了「空间智能究竟是什么?它为什么重要?我们如何构建它?我们又如何使用它?」她同时阐述了真正的空间智能世界模型必须实现的核心框架:构建具有故事讲述者想象力的 AI、具备第一响应者流畅性的 AI 以及以科学精确性进行空间推理。 以下为全文翻译: 1950 年,当计算机还只


调用服务出现网络错误的问题排查与解决
360_go_php2025/11/10

在分布式系统和微服务架构中,服务之间的调用是常见的操作。然而,有时在调用某个外部服务时,可能会遇到网络错误或连接失败的情况。这类问题可能与网络环境、域名解析、DNS 配置等因素相关,给服务的稳定性和可用性带来影响。​编辑 本文将介绍如何排查和解决调用服务时出现网络错误的问题,最终通过 ping 命令确认错误接口的域名,并通过本地 hosts 文件检查和修改解析,解决了因 DNS 配置问题引起的服务调用失败。 1. 问题背景​编辑 在调用某个外部服务时,应用程序报错,提示无法访问目标服务,或者出现


一份实用的Vue3技术栈代码评审指南
至简简2025/11/8

CSS 优先使用 **scoped**  防止样式污染全局,每个组件样式必须局部化。 错误示例:无作用域 <style> .button { color: red; } </style>  不加 scoped 会影响全局所有 .button 正确示例:使用 scoped <style scoped> .button { color: red; } </style> 限制嵌套层级 ≤ 3 层 嵌套超过 3 层说明选择器设计有问题,建议拆分样式或使用 BEM。 错误示例:嵌套过深(5 层


Ant Design Landing模版使用教程-react-npm
I like Code?2025/11/4

特此鸣谢:https://github.com/ant-motion/ant-design-3.x-landing-page?tab=readme-ov-file 官网(不好用):https://landing.ant.design/docs/introduce-cn package.json代码如下 { "private": true, "entry": { "index": "./index.js" }, "dependencies": { "antd"


硬件岗位基础知识
千語萬言-2025/10/31

1. 为什么 I2C 要上拉电阻? 因为 I2C 芯片的物理输出是“开漏输出”,它自身无法输出高电平,需要上拉电阻来提供高电平。 a) 电气结构:开漏输出 I2C 总线上的每一个设备(主设备和从设备),其 SDA(数据线)和 SCL(时钟线)的物理输出级都是一个 开漏输出 或 开集输出 的电路。 b) 上拉电阻的作用 提供高电平、限流保护 2.解释 交流电 和 直流电 直流电 (DC - Direct Current) 含义:电流的方向和大小不随时间变化。 交流电 (A


C#.NET DbContext 池化机制深入解析:提升 EF Core 性能的关键
唐青枫2025/10/29

简介 DbContext 池是 Entity Framework Core 中的高性能数据库连接管理机制,通过重用已初始化的 DbContext 实例,显著减少创建和销毁上下文对象的开销,特别适合高并发场景。尤其在高并发场景(如 Web API)中,频繁创建和释放 DbContext 会导致: 性能瓶颈:实例化 DbContext 涉及反射、元数据初始化和连接池分配。 内存压力:频繁创建和释放会导致垃圾回收(GC)压力。 连接管理问题:不恰当的 DbContext 生命周期可能导致数

首页编辑器站点地图

Copyright © 2025 聚合阅读

License: CC BY-SA 4.0