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

Leecode热题100---46:全排列(递归)

题目
给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。
在这里插入图片描述
思路
元素交换+函数递归
通过交换元素来实现全排列。即对于[x, nums.size()]中的元素,for循环遍历每个元素分别成为第一个元素;
然后再对[x + 1, nums.size()-1)递归调用排列函数,直到 x == nums.size()-1 递归终止。

C++

#include<iostream>
#include<vector>
using namespace std;class Soluiton
{
private:vector<vector<>int>res;//通过交换元素来实现全排列。即对于[x, nums.size()]中的元素,for循环遍历每个元素分别成为第一个元素,//然后再对[x + 1, end-1)递归调用排列函数,直到 x == nums.size()-1 递归终止。void dfs(vector<int>nums,int x){if(x == nums.size() - 1){res.push_back(nums);	//添加排列方案return;}for(int i = x;i<nums.size(); i++){swap(nums[i],nums[x]);	// 交换,将nums[i]固定在第x位dfs(nums,x+1);			// 开启固定第 x+1 位元素swap(nums[i],nums[x]);	// 恢复交换}}public:vector<vector<int>> permute(vector<int>& nums){dfs(nums,0);return res;}
};

python:

class Solution:def permute(self,nums):res = []def dfs(x):if x == len(nums)-1:res.append(list(nums))      # 添加排列方案returnfor i in range(x,len(nums)):nums[i], nums[x] = nums[x], nums[i]     # 交换,将 nums[i] 固定在第 x 位dfs(x+1)                                # 开启固定第 x + 1 位元素nums[i], nums[x] = nums[x], nums[i]     # 恢复交换dfs(0)return res
http://www.lryc.cn/news/354898.html

相关文章:

  • Android 多语言
  • Thingsboard规则链:Message Type Filter节点详解
  • SQLI-labs-第二十五关和第二十五a关
  • Windows、Linux添加路由
  • Swift 初学者交心:在 Array 和 Set 之间我们该如何抉择?
  • C++ 类模板 函数模板
  • OTP8脚-全自动擦鞋机WTN6020-低成本语音方案
  • GpuMall智算云:meta-llama/llama3/Llama3-8B-Instruct-WebUI
  • 内存泄漏案例分享4-异步任务流内存泄漏
  • 【机器学习300问】100、怎么理解卷积神经网络CNN中的池化操作?
  • RPA机器人流程自动化如何优化人力资源工作流程
  • OpenHarmony开发者大会2024:鸿心聚力 智引未来
  • 新楚文化知网收录文学艺术类期刊投稿
  • 基于vue3速学angular
  • 链游中的代币(Token)或加密货币(Cryptocurrency)是如何产生和使用的?
  • 2024年5月23日 (周四) 叶子游戏新闻
  • 猫毛过敏终结者!宠物空气净化器让你告别红眼和喷嚏
  • xgboost项目实战-保险赔偿额预测与信用卡评分预测001
  • 子网划分,交换机原理与配置
  • 记mapboxGL实现鼠标经过高亮时的一个问题
  • AI重塑了我的工作流
  • vue使用Less报错semi-colon expectedcss(css-semicolonexpected)的解决方法
  • 如何使用golang自带工具对代码进行覆盖率测试
  • Android studio版本和Android gradle plugin版本对应表
  • JavaRedis-主从集群-分片-数据结构-回收处理-缓存问题
  • Java原生JDBC概览
  • C# 跨线程访问UI组件,serialPort1串口接收数据
  • D - New Friends(AtCoder Beginner Contest 350)
  • 【FAQ】HarmonyOS SDK 闭源开放能力 —Account Kit(2)
  • Web组态可视化编辑器 快速绘制组态图