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阅读更多 →
3步构建ESP32物联网水产养殖监控系统:从零到智能控制

3步构建ESP32物联网水产养殖监控系统:从零到智能控制

3步构建ESP32物联网水产养殖监控系统:从零到智能控制 【免费下载链接】arduino-esp32 Arduino core for the ESP32 family of SoCs 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 想象一下,深夜鱼塘突然缺氧,你却在…

2026/6/17 17:29:57阅读更多 →
机器学习从零实现:企业级AI教育转型的5大技术优势与实施指南

机器学习从零实现:企业级AI教育转型的5大技术优势与实施指南

机器学习从零实现:企业级AI教育转型的5大技术优势与实施指南 【免费下载链接】ML-From-Scratch Machine Learning From Scratch. Bare bones NumPy implementations of machine learning models and algorithms with a focus on accessibility. Aims to cover every…

2026/6/17 17:29:57阅读更多 →
从原理到实践:在Unreal中构建基于波叠加的动态水面材质

从原理到实践:在Unreal中构建基于波叠加的动态水面材质

1. 为什么我们需要波叠加技术 第一次在游戏中看到逼真的水面效果时,那种震撼感至今难忘。记得多年前玩《盗贼之海》,船只在起伏的海浪中穿行,阳光在水面折射出的光斑,还有浪花拍打船身的细节,都让我惊叹不已。这种效果…

2026/6/17 17:29:57阅读更多 →
【网工入门-eNSP模拟-10】ACL访问控制列表

【网工入门-eNSP模拟-10】ACL访问控制列表

ACL(Access Control List,访问控制列表) 是一系列规则的集合。它的核心作用是对网络中的数据包进行“识别”和“分类”,然后根据识别结果,决定是允许(Permit) 还是拒绝(Deny&#xf…

2026/6/17 17:29:57阅读更多 →
豆包两大工程级指令:保真压缩与多立场萃取实战指南

豆包两大工程级指令:保真压缩与多立场萃取实战指南

1. 项目概述:为什么这两个豆包指令值得反复验证 “多次尝试,这两个豆包指令真的真实”——这句话不是营销话术,也不是社群里常见的跟风转发,而是我过去三个月在真实工作流中反复压测、交叉验证后写下的结论。作为长期用AI工具重构…

2026/6/17 17:29:57阅读更多 →
RSOME:用NumPy风格语法轻松实现鲁棒与分布鲁棒优化

RSOME:用NumPy风格语法轻松实现鲁棒与分布鲁棒优化

1. 项目概述 如果你在Python里做过优化建模,大概率用过 PuLP 、 CVXPY 或者 Pyomo 。这些工具各有千秋,但当我第一次接触到 RSOME (Robust Stochastic Optimization Made Easy)时,感觉像是发现了一个新大陆。它…

2026/6/17 17:24:54阅读更多 →
飞书机器人接入 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阅读更多 →