当前位置: 首页 > article >正文

蓝桥杯备赛:Day5-P1706 全排列问题

算法笔记P1706 全排列问题 (DFS 基础)1. 题目描述P1706 全排列问题 - 洛谷输出1 ∼ N 1 \sim N1∼N的所有全排列要求每个数字占5 个场宽排列按字典序从小到大输出。2. 核心代码 (C 版本)#include bits/stdc.h using namespace std; typedef long long ll; ll N; ll ans[15]; // 记录当前位置存了哪个数字 bool used[15]; // 标记数字 i 是否已被使用 void dfs(int position) { // 1. 递归出口当位置超过 N 时说明 N 个坑位已填满 if(position N) { for(int i 1; i N; i) { cout setw(5) ans[i]; // 核心格式控制 } cout \n; return; // 功成身退回溯到上一层 } // 2. 尝试在当前位置填入数字 i for(int i 1; i N; i) { if(!used[i]) // 只有没用过的数字才能填入 { ans[position] i; // 填入数字 used[i] true; // 标记为已占用 dfs(position 1); // 递归进入下一个位置 used[i] false; // 【核心回溯】撤销标记释放数字 } } } void solve() { if(!(cin N)) return; dfs(1); } int main() { ios::sync_with_stdio(0); cin.tie(0), cout.tie(0); int _ 1; while(_--) { solve(); } return 0; }3. 核心考点与注意事项DFS 递归模型本题体现了 DFS 最经典的思想——“不撞南墙不回头”。通过递归不断深入直到触发出口条件。回溯机制 (Backtracking)used[i] false;是整段代码的灵魂。它保证了在完成一种排列并返回后之前使用的数字能被释放从而参与到其他分支的排列中。状态维护position记录递归的深度即当前的坑位。i记录横向的选择范围即手里的数字。格式要求setw(5)是iomanip库中的函数万能头已包含用于满足题目严格的场宽要求。️ 深度拆解第二层工人的“工作日志”假设N 3 N3N3第二层工人的任务是填好第二个坑位ans[2]。第一阶段尝试数字 2开始循环工人看手里有哪些牌。数字1 11被第一层拿走了数字2 22还没人用。填坑他在第二个坑里填入2ans[2] 2并标记used[2] true。派发任务他大喊一声“第三层剩下的交给你了”然后调用dfs(3)。原地待命此时第二层工人的程序暂停在了dfs(3)这一行他进入了漫长的等待。第二阶段回火Backtracking任务返回过了一会儿第三层跑完回来了也就是1 2 3已经打印完了。苏醒第二层工人“苏醒”过来接着执行dfs(3)下面的代码。撤销操作他执行used[2] false。这意味着他把数字2从坑里拿了出来重新放回手里。这一步极其关键因为它让数字 2 重新变回了“可用状态”。第三阶段开启新分支i 变成 3继续循环因为他还在for循环里执行完刚才那两行后i发生了。寻找下一张牌现在i变成了3。检查可用性他发现数字3 33也没被用过used[3]是false。新的尝试他在第二个坑里填入新的数字ans[2] 3。标记used[3] true。再次大喊“第三层我又来了”调用dfs(3)。4. 易错点回顾 (My Mistakes)1. return 位置导致的“截断”错误错误经历曾将return放在if块之外导致函数刚进入就直接结束无法进入下方的for循环。教训在 DFS 中return通常只出现在递归出口Base Case中代表当前路径搜索完毕。2. 回溯的必要性理解反思如果不写used[i] false数字被用过一次后就永远失效最终只能输出1 2 3 ... N这一种结果无法生成其他排列。

相关文章:

蓝桥杯备赛:Day5-P1706 全排列问题

&#x1f4da; 算法笔记&#xff1a;P1706 全排列问题 (DFS 基础) 1. 题目描述 P1706 全排列问题 - 洛谷 输出 1∼N1 \sim N1∼N 的所有全排列&#xff0c;要求每个数字占 5 个场宽&#xff0c;排列按字典序从小到大输出。 2. 核心代码 (C 版本) #include <bits/stdc.h…...

微信聊天记录永久保存终极指南:用WeChatMsg轻松掌控你的数字记忆

微信聊天记录永久保存终极指南&#xff1a;用WeChatMsg轻松掌控你的数字记忆 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trendin…...

OpenClaw学习监督助手:Qwen3-14b_int4_awq制定计划与检查进度

OpenClaw学习监督助手&#xff1a;Qwen3-14b_int4_awq制定计划与检查进度 1. 为什么需要AI学习监督助手 去年备考PMP认证时&#xff0c;我经历过一段痛苦的自我管理期。每天下班后面对厚厚的PMBOK指南&#xff0c;总在"今天该看哪章"和"上次看到哪里"之间…...

【海洋空间信息工程概论 实验报告4】空间数据投影变换

上一篇&#xff1a;【海洋空间信息工程概论 实验报告3】海洋数据矢量化 目录 一、实验目的 二、实验环境 三、实验内容 实验步骤 ​编辑 实验心得 一、实验目的 由于数据源的多样性&#xff0c;当数据与我们研究、分析问题的空间参考系统&#xff08;坐标系统、投影方式…...

植物大战僵尸终极辅助工具:PVZ Toolkit完整使用指南

植物大战僵尸终极辅助工具&#xff1a;PVZ Toolkit完整使用指南 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit PVZ Toolkit是一款专为经典游戏《植物大战僵尸》PC版设计的开源修改工具&#xff0c…...

《被讨厌的勇气》自我救赎入门之书

一直觉得&#xff0c;人这一生&#xff0c;最难的功课是与自己和解&#xff0c;是挣脱他人的眼光&#xff0c;活成真实的自己。而我这份觉醒&#xff0c;始于一本心理学入门书——《被讨厌的勇气》。很多人困在人际关系的枷锁里&#xff0c;活得小心翼翼、疲惫不堪。习惯了迎合…...

BepInEx:Unity游戏插件开发的终极框架完全指南

BepInEx&#xff1a;Unity游戏插件开发的终极框架完全指南 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx BepInEx&#xff08;Bepis Injector Extensible&#xff09;是一款专为U…...

效率利器:借助快马平台为极域课堂快速打造一站式密码管理助手

最近在帮学校的信息技术老师处理极域课堂管理系统v6.0的密码管理问题时&#xff0c;发现老师们经常需要处理三类高频需求&#xff1a;快速生成符合要求的密码、评估现有密码强度、解答常见密码问题。传统做法要么依赖纸质记录&#xff0c;要么需要临时编写脚本&#xff0c;效率…...

Windows环境下突破性macOS恢复盘制作终极指南:无需Mac设备也能创建官方纯净镜像

Windows环境下突破性macOS恢复盘制作终极指南&#xff1a;无需Mac设备也能创建官方纯净镜像 【免费下载链接】gibMacOS Py2/py3 script that can download macOS components direct from Apple 项目地址: https://gitcode.com/gh_mirrors/gi/gibMacOS 还在为没有Mac设备…...

MSPM0G3507开发实战:Keil环境下多款仿真器(CMSIS-DAP/ST-Link/J-Link)与UniFlash下载全攻略

1. 为什么选择Keil开发MSPM0G3507&#xff1f; 对于嵌入式开发者来说&#xff0c;选择一款趁手的开发环境往往能事半功倍。我在多个项目中测试过不同开发环境后&#xff0c;发现Keil MDK在MSPM0G3507开发中确实有不少优势。首先是生态支持完善&#xff0c;TI官方提供的SDK和示例…...

效率倍增:将matlab算法思路在快马平台秒级转化为可运行web应用

今天想和大家分享一个提升算法验证效率的小技巧——如何把MATLAB里的算法思路快速转化为可运行的Web应用。作为一个经常需要验证信号处理算法的人&#xff0c;我发现MATLAB虽然强大&#xff0c;但每次启动软件、初始化项目都要耗费不少时间。后来尝试用InsCode(快马)平台后&…...

告别PWM!用STM32串口轻松驱动幻尔16路舵机控制板(附完整代码)

STM32串口驱动幻尔16路舵机控制板的实战指南 从PWM到串口&#xff1a;舵机控制的技术演进 记得我第一次尝试用STM32控制机械臂时&#xff0c;光是配置PWM定时器就花了两天时间。每个舵机需要独立的PWM通道&#xff0c;复杂的定时器分频计算&#xff0c;还有那令人头疼的占空比换…...

大模型时代:TranslateGemma在AI翻译领域的突破

大模型时代&#xff1a;TranslateGemma在AI翻译领域的突破 在机器翻译领域&#xff0c;我们正见证着一个激动人心的转折点。传统翻译工具往往在专业术语、文化语境和语言细微差别面前显得力不从心&#xff0c;而新一代大模型正在彻底改变这一局面。TranslateGemma作为基于Gemm…...

别再乱调Spacing了!用SimpleITK给医学图像做重采样,这份避坑指南请收好

医学图像重采样实战&#xff1a;如何科学设置Spacing参数提升模型性能 当你在处理3D医学图像时&#xff0c;是否遇到过这样的困惑&#xff1a;明明按照教程完成了重采样&#xff0c;但模型性能却不升反降&#xff1f;或者在不同数据集上使用相同的Spacing参数&#xff0c;效果…...

别再用ChatGPT写代码了!试试Cursor的Ctrl+K和Ctrl+L,效率提升不止一倍

从ChatGPT到Cursor&#xff1a;AI编程助手的效率革命 1. 为什么开发者需要更高效的AI编程工具&#xff1f; 在过去的两年里&#xff0c;AI编程助手已经从科幻概念变成了开发者日常工作的一部分。ChatGPT等通用AI工具虽然强大&#xff0c;但在专业编程场景中仍存在诸多局限&…...

Xilinx Aurora 8B/10B IP核(5):GT资源规划实战——从PCB引脚到IP核Lane的映射法则

1. 从PCB引脚到IP核Lane的映射挑战 刚接触Xilinx Aurora 8B/10B IP核配置时&#xff0c;最让我头疼的就是这个"物理到逻辑"的映射问题。记得第一次调试时&#xff0c;明明IP核配置界面显示链路已建立&#xff0c;但实际硬件就是无法通信&#xff0c;后来发现是Lane分…...

数据结构之B树、B+树、B-树详解

B树、B树、B-树详解 目录 1. 引言2. B树&#xff08;B-Tree&#xff09; 2.1 定义2.2 特点2.3 操作2.4 应用场景 3. B树&#xff08;B Tree&#xff09; 3.1 定义3.2 特点3.3 操作3.4 应用场景 4. B-树&#xff08;B-Tree&#xff09; 4.1 定义4.2 特点4.3 操作4.4 应用场景 …...

Asian Beauty Z-Image Turbo 硬件需求详解:从消费级到专业级GPU配置

Asian Beauty Z-Image Turbo 硬件需求详解&#xff1a;从消费级到专业级GPU配置 1. 引言 最近有不少朋友在尝试跑一些新的图像生成模型时&#xff0c;遇到了一个挺实际的问题&#xff1a;我的显卡到底行不行&#xff1f;特别是像 Asian Beauty Z-Image Turbo 这类对画质和速度…...

OpenCV多线程编程:从单线程到多线程的视频处理

一、最简单的摄像头显示程序让我们从最基础的版本开始&#xff1a;一个单线程程序&#xff0c;直接从摄像头读取并显示画面。基础版本代码#include <iostream> #include <opencv2/opencv.hpp> using namespace std;int main() {// 打开摄像头&#xff08;默认摄像头…...

Jetson Orin Nano 上跑 DeepSeek 模型实测:1.5B 和 7B 哪个更香?附完整部署流程

Jetson Orin Nano 深度评测&#xff1a;1.5B vs 7B 模型实战指南 当边缘计算遇上大语言模型&#xff0c;如何在资源受限的硬件上实现最优性能&#xff1f;作为英伟达边缘计算产品线的明星设备&#xff0c;Jetson Orin Nano凭借其紧凑体积和强大算力&#xff0c;成为众多开发者在…...

蒙特卡洛模拟的颠覆性突破:OpenMC如何通过多源采样与方差缩减技术解决计算效率瓶颈

蒙特卡洛模拟的颠覆性突破&#xff1a;OpenMC如何通过多源采样与方差缩减技术解决计算效率瓶颈 【免费下载链接】openmc OpenMC Monte Carlo Code 项目地址: https://gitcode.com/gh_mirrors/op/openmc 在核工程、粒子物理和辐射屏蔽等领域&#xff0c;蒙特卡洛模拟一直…...

Xournal++终极指南:免费手写笔记与PDF批注完整教程

Xournal终极指南&#xff1a;免费手写笔记与PDF批注完整教程 【免费下载链接】xournalpp Xournal is a handwriting notetaking software with PDF annotation support. Written in C with GTK3, supporting Linux (e.g. Ubuntu, Debian, Arch, SUSE), macOS and Windows 10. S…...

Open-AutoGLM自动化测试:用自然语言编写移动应用测试用例

Open-AutoGLM自动化测试&#xff1a;用自然语言编写移动应用测试用例 1. 项目概述 Open-AutoGLM是由智谱AI开源的一款革命性手机端智能助理框架&#xff0c;专为自动化手机操作而设计。该项目基于AutoGLM架构构建&#xff0c;采用Apache-2.0开源协议&#xff0c;完全免费且支…...

Arduino非阻塞编程:Pin与WaitDo轻量级嵌入式工具库

1. 项目概述HDW-Utils 是一个面向 Arduino 平台的轻量级嵌入式工具库&#xff0c;其核心设计目标并非提供底层硬件驱动&#xff0c;而是解决嵌入式开发中高频出现的代码重复性、结构松散性与阻塞式延时滥用三大工程痛点。该库以“硬件开发者的实用主义”为出发点&#xff0c;通…...

鸽姆智库真理纪元白皮书(学术修订版)真理纪元:贾子科学定理与人类逻辑主权的学术纲要

鸽姆智库真理纪元白皮书&#xff08;学术修订版&#xff09;真理纪元&#xff1a;贾子科学定理与人类逻辑主权的学术纲要摘要《真理纪元》以贾子科学定理为理论基石&#xff0c;旨在修正波普尔证伪主义百余年间对科学认知范式的垄断影响。本文以112作为科学体系的基础公理与确定…...

真理纪元:贾子科学定理与人类逻辑主权的学术白皮书

真理纪元&#xff1a;贾子科学定理与人类逻辑主权的学术白皮书作者单位&#xff1a;鸽姆智库&#xff08;GG3M Think Tank&#xff09;作者简介&#xff1a;贾子&#xff08;Kucius&#xff09;&#xff0c;研究员&#xff0c;鸽姆智库&#xff08;GG3M Think Tank&#xff09;…...

Java全栈开发面试实战:从基础到项目落地的完整技术旅程

Java全栈开发面试实战&#xff1a;从基础到项目落地的完整技术旅程 面试场景描述 在一家知名互联网大厂&#xff0c;一位名叫李晨阳的28岁程序员正在接受一场紧张而富有挑战性的面试。他拥有计算机科学与技术硕士学位&#xff0c;有5年全栈开发经验&#xff0c;曾参与多个大型项…...

猫抓扩展完整配置指南:从零开始掌握浏览器资源嗅探

猫抓扩展完整配置指南&#xff1a;从零开始掌握浏览器资源嗅探 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为网页上的视频无法下载而烦恼吗…...

基于Matlab/Simulink的直流电机双闭环调速系统参数优化与动态响应分析

1. 直流电机双闭环调速系统基础认知 第一次接触直流电机双闭环调速系统时&#xff0c;我被那一堆专业术语绕得头晕——什么ASR、ACR、转速环电流环&#xff0c;感觉像在听天书。后来在实际项目中摸爬滚打才发现&#xff0c;这套系统本质上就是个"双保险"设计。想象一…...

Phi-4-mini-reasoning效果展示:数学符号识别+语义理解+推理三重能力

Phi-4-mini-reasoning效果展示&#xff1a;数学符号识别语义理解推理三重能力 1. 模型概览 Phi-4-mini-reasoning是一款3.8B参数的轻量级开源模型&#xff0c;专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这款由Azure AI Foundry推出的模型主打"小参数、强推理、…...