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

【LeetCode-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]]
代码实现:
class Solution {public List<List<Integer>> permute(int[] nums) {List<List<Integer>> res = new ArrayList<List<Integer>>();List<Integer> output = new ArrayList<Integer>();for (int num : nums) {output.add(num);}int n = nums.length;backtrack(n, output, res, 0);return res;}public void backtrack(int n, List<Integer> output, List<List<Integer>> res, int first) {// 所有数都填完了if (first == n) {res.add(new ArrayList<Integer>(output));}for (int i = first; i < n; i++) {// 动态维护数组Collections.swap(output, first, i);// 继续递归填下一个数backtrack(n, output, res, first + 1);// 撤销操作Collections.swap(output, first, i);}}
}

http://www.lryc.cn/news/322856.html

相关文章:

  • 【Web】浅聊Jackson序列化getter的利用——POJONode
  • osgEarth学习笔记2-第一个Osg QT程序
  • 2024年发布jar到国外maven中央仓库最新教程
  • 在ubuntu22.04.4安装freeswitch1.10.10
  • qt 置顶窗口崩溃无法退出解决,停止运行快捷键设置
  • HBCalculator 程序:通过 VMD 可计算分子动力学模拟中氢键密度和强度的一维和二维分布
  • 鸿蒙-项目创建及了解
  • SQLiteC/C++接口详细介绍sqlite3_stmt类(九)
  • idea2023 运行多 springboot 实例
  • HarmonyOS系统开发ArkTS常用组件编程技巧
  • 大数据开发(Hive面试真题-卷三)
  • Oracle数据库SQL开发规范
  • FreeRTOS 消息队列
  • 如何在Python中实现列表推导式?并给出一个例子
  • Flask中的Blueprints:模块化和组织大型Web应用【第142篇—Web应用】
  • 如何通过idea搭建一个SpringBoot的Web项目(最基础版)
  • Python和FastAPI语义分析和文本图像
  • centos系统ssh7.4升级9.6
  • excel所有知识点
  • 显卡基础知识及元器件原理分析
  • Spark Rebalance hint的倾斜的处理(OptimizeSkewInRebalancePartitions)
  • Vue 3中实现基于角色的权限认证实现思路
  • Visual Studio 2022进行文件差异比较
  • 1.2 编译型语言和解释型语言的区别
  • C语言-常量
  • 开源的OCR工具基本使用:PaddleOCR/Tesseract/CnOCR
  • vue3实现输入框短信验证码功能---全网始祖
  • [C#]winformYOLO区域检测任意形状区域绘制射线算法实现
  • 个人网站制作 Part 14 添加网站分析工具 | Web开发项目
  • 数据按设定单位(分辨率)划分的方法