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阅读更多 →
RSOME:用NumPy风格语法轻松实现鲁棒与分布鲁棒优化

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

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

2026/6/17 17:24:54阅读更多 →
I2S音频接口时钟系统全解析:从MCLK到LRCK的实战计算

I2S音频接口时钟系统全解析:从MCLK到LRCK的实战计算

1. I2S音频接口时钟系统基础 第一次接触I2S接口时,我被那一堆时钟信号搞得晕头转向。MCLK、SCLK、LRCK...这些看似简单的时钟信号,在实际项目中却能让不少工程师栽跟头。记得去年调试一块音频板卡时,就因为搞错了MCLK分频比,导致…

2026/6/17 17:24:54阅读更多 →
社群运营329模型:从引流到转化的结构化实战指南

社群运营329模型:从引流到转化的结构化实战指南

1. 项目概述:从“qun329”看社群运营的底层逻辑与实战体系 最近在复盘几个做得还不错的私域项目时,我反复看到一个高频出现的词:“qun329”。这乍一看像是个随意的代号,但深入接触过一些操盘手和深度用户后,我发现&…

2026/6/17 17:24:54阅读更多 →
模板驱动型文档自动化:结构化内容与零代码自动化实践

模板驱动型文档自动化:结构化内容与零代码自动化实践

1. 项目概述:当文档生产变成“填空游戏” 你有没有经历过这种场景:每周一早上,市场部同事准时把一份PDF格式的电子书封面发到群里,标题是《2024Q2行业洞察白皮书》,副标题写着“数据驱动增长新范式”;三小时…

2026/6/17 17:24:54阅读更多 →
每日热门skill:你的AI终于能管项目了:Linear Skill如何让Agent成为团队最靠谱的PM

每日热门skill:你的AI终于能管项目了:Linear Skill如何让Agent成为团队最靠谱的PM

从"被动响应"到"主动管理",一个Skill让AI Agent掌控项目全流程 一、开篇:为什么你的AI Agent需要Linear? 想象一下这个场景: 周一早上,你打开Linear,发现周末有12个Issue被分配给你&…

2026/6/17 17:24:54阅读更多 →
Mermaid Live Editor:告别复杂图表工具,三步实现专业可视化创作

Mermaid Live Editor:告别复杂图表工具,三步实现专业可视化创作

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…

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