LeetCode--46.全排列(回溯算法)
46.全排列题目描述给定一个不含重复数字的数组nums返回其所有可能的全排列。你可以按任意顺序返回答案。示例 1输入nums [1,2,3] 输出[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2输入nums [0,1] 输出[[0,1],[1,0]]示例 3输入nums [1] 输出[[1]]提示1 nums.length 6-10 nums[i] 10nums中的所有整数互不相同代码classSolution{// 存放所有排列结果ListListIntegerresultnewArrayList();// 当前路径当前排列ListIntegerpathnewArrayList();/** * 回溯函数 * * param nums 原数组 * param used used[i] 表示 nums[i] 是否已经被使用 */publicvoidbacktracking(int[]nums,int[]used){/** * 终止条件 * * 当当前路径长度等于数组长度时 * 说明已经形成一个完整排列 */if(path.size()nums.length){// 加入结果集result.add(newArrayList(path));return;}/** * 全排列 * 每一层都要从 0 开始遍历 * * 因为 * 每个位置都可以放任意未使用元素 */for(inti0;inums.length;i){/** * 如果当前元素没有被使用 */if(used[i]0){// 做选择加入当前元素path.add(nums[i]);// 标记当前元素已使用used[i]1;// 递归下一层backtracking(nums,used);// 回溯恢复现场// 当前元素恢复未使用状态used[i]0;// 删除路径最后一个元素path.remove(path.size()-1);}}}publicListListIntegerpermute(int[]nums){/** * used数组 * * used[i] 1 * 表示 nums[i] 已经在当前路径中 * * used[i] 0 * 表示 nums[i] 还未使用 */int[]usednewint[nums.length];backtracking(nums,used);returnresult;}}

相关新闻

3天从零开始:用Arduino-ESP32打造你的第一个智能物联网项目

3天从零开始:用Arduino-ESP32打造你的第一个智能物联网项目

3天从零开始:用Arduino-ESP32打造你的第一个智能物联网项目 【免费下载链接】arduino-esp32 Arduino core for the ESP32 family of SoCs 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 想要快速入门ESP32开发却不知从何下手?…

2026/6/17 13:21:50阅读更多 →
PX4飞控系统完整入门指南:从零搭建无人机自主飞行平台

PX4飞控系统完整入门指南:从零搭建无人机自主飞行平台

PX4飞控系统完整入门指南:从零搭建无人机自主飞行平台 【免费下载链接】PX4-Autopilot PX4 Autopilot Software 项目地址: https://gitcode.com/gh_mirrors/px/PX4-Autopilot 想要快速掌握无人机自主飞行的核心技术?PX4飞控系统作为业界领先的开源…

2026/6/17 13:21:50阅读更多 →
3分钟上手Mermaid Live Editor:零代码画图原来这么简单!

3分钟上手Mermaid Live Editor:零代码画图原来这么简单!

3分钟上手Mermaid Live Editor:零代码画图原来这么简单! 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermai…

2026/6/17 13:21:50阅读更多 →
i.MX GPU工具链实战:纹理压缩、内存监控与API追踪优化指南

i.MX GPU工具链实战:纹理压缩、内存监控与API追踪优化指南

1. 项目概述:i.MX GPU工具链与内存管理实战在嵌入式图形开发领域,尤其是基于NXP i.MX系列处理器的项目里,图形性能的优化往往是一场与有限硬件资源的“博弈”。CPU算力、GPU带宽、内存容量,每一项都可能成为制约流畅体验的瓶颈。很…

2026/6/17 17:09:44阅读更多 →
MC9S12NE64端口复用与LCD驱动:嵌入式网络设备开发实战解析

MC9S12NE64端口复用与LCD驱动:嵌入式网络设备开发实战解析

1. 项目概述与核心价值如果你正在捣鼓一块基于MC9S12NE64的开发板,特别是像EVB9S12NE64这样的评估板,那你大概率是在做一个带网络功能的嵌入式设备。这块芯片最吸引人的地方,就是它把16位HCS12内核和以太网MAC/PHY给塞到了一起,让…

2026/6/17 17:09:44阅读更多 →
终极免费方案:如何零成本解锁WeMod全部高级游戏修改功能

终极免费方案:如何零成本解锁WeMod全部高级游戏修改功能

终极免费方案:如何零成本解锁WeMod全部高级游戏修改功能 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 还在为WeMod Pro的高昂订阅费用而犹…

2026/6/17 17:09:44阅读更多 →
BaiduPCS-Go终极指南:三步搞定百度网盘命令行高效管理

BaiduPCS-Go终极指南:三步搞定百度网盘命令行高效管理

BaiduPCS-Go终极指南:三步搞定百度网盘命令行高效管理 【免费下载链接】BaiduPCS-Go 项目地址: https://gitcode.com/gh_mirrors/baid/BaiduPCS-Go 你是否厌倦了百度网盘繁琐的网页界面和缓慢的客户端体验?BaiduPCS-Go正是为你量身打造的百度网盘…

2026/6/17 17:09:44阅读更多 →
5分钟快速上手:Obsidian-i18n终极汉化插件完整指南

5分钟快速上手:Obsidian-i18n终极汉化插件完整指南

5分钟快速上手:Obsidian-i18n终极汉化插件完整指南 【免费下载链接】obsidian-i18n 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-i18n 你是否曾经因为Obsidian插件全是英文界面而感到困扰?面对密密麻麻的英文设置选项,每次…

2026/6/17 17:09:44阅读更多 →
基于S12ZVM的BLDC电机六步换相控制:从原理到工程实践

基于S12ZVM的BLDC电机六步换相控制:从原理到工程实践

1. 项目概述与核心思路 在嵌入式开发领域,电机控制一直是一个兼具挑战与魅力的方向。它要求开发者不仅要懂软件,还要理解硬件、电力电子和电机本体的物理特性。几年前,当我第一次接触无刷直流(BLDC)电机时,…

2026/6/17 17:04:43阅读更多 →
飞书机器人接入 OpenClaw 完整落地部署指南(含安装包)

飞书机器人接入 OpenClaw 完整落地部署指南(含安装包)

OpenClaw 2.7.9 对接飞书机器人完整配置教程 本文讲解借助长连接模式打通 OpenClaw 与飞书的操作流程,配置完成后,可在飞书私聊、群组内发送指令,调用本地 AI 实现电脑自动化操作。整体流程分为飞书平台创建应用、权限配置、密钥填写三大环节…

2026/6/17 10:40:20阅读更多 →
嵌入式处理器技术演进与飞思卡尔实战解析:从架构选型到系统设计

嵌入式处理器技术演进与飞思卡尔实战解析:从架构选型到系统设计

1. 嵌入式处理器:从“大脑”到“神经系统”的进化 在电子设备无处不在的今天,我们很少会去思考一个智能设备是如何“思考”和“行动”的。无论是汽车引擎的精准控制、工厂机械臂的流畅运转,还是智能家居的自动响应,其背后都离不开…

2026/6/17 10:40:20阅读更多 →
如何高效使用BallonTranslator:3分钟完成漫画翻译的完整实用指南

如何高效使用BallonTranslator:3分钟完成漫画翻译的完整实用指南

如何高效使用BallonTranslator:3分钟完成漫画翻译的完整实用指南 【免费下载链接】BallonsTranslator 深度学习辅助漫画翻译工具, 支持一键机翻和简单的图像/文本编辑 | Yet another computer-aided comic/manga translation tool powered by deeplearning 项目地…

2026/6/17 10:40:20阅读更多 →