每日一题——没有重复项数字的全排列

没有重复项数字的全排列

    • 示例
    • 题解
      • 思路
      • 代码实现
      • 代码解释
      • 时间复杂度与空间复杂度分析
    • 讨论

建议先看视频讲解

## 题目

给出一组数字,返回该组数字的所有排列。例如,给定输入 [1,2,3],其所有排列如下:

[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]

排列是按字典序输出的。

数据范围:

  • 数字个数 0 < n ≤ 6 0 < n \leq 6 0<n6

要求:

  • 时间复杂度: O ( n ! ) O(n!) O(n!)
  • 空间复杂度: O ( n ! ) O(n!) O(n!)

示例

示例 1:

输入:

[1,2,3]

返回值:

[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

示例 2:

输入:

[1]

返回值:

[[1]]

题解

该问题可以通过回溯算法解决。回溯算法的核心思想是通过递归遍历所有可能的排列,同时通过标记来避免重复选取相同的数字。

思路

  1. 使用回溯方法生成所有排列。
  2. 在每一步选择一个数字加入当前排列,并且递归处理剩下的数字。
  3. 一旦一个排列生成完成,将其保存到结果列表中。
  4. 使用一个used数组来标记哪些元素已经在当前排列中被使用过,避免重复。

代码实现

#include <stdio.h>
#include <stdlib.h>// 回溯函数:生成全排列
void backtrack(int* num, int numLen, int** result, int* returnSize,int* returnColumnSizes, int* current, int currentLen, int* used) {// num: 输入的数字数组// numLen: 数组的长度// result: 用于存储所有排列的二维数组// returnSize: 当前已生成的排列数量// returnColumnSizes: 用于存储每个排列的列大小// current: 当前正在构建的排列// currentLen: 当前排列的长度// used: 标记数组,记录哪些元素已经被使用// 如果当前排列长度等于数字长度,说明一个排列已生成if (currentLen == numLen) {// 为当前排列分配内存result[*returnSize] = (int*)malloc(sizeof(int) * numLen);// 将当前排列复制到结果数组中for (int i = 0; i < numLen; i++) {result[*returnSize][i] = current[i];}// 设置当前排列的列大小returnColumnSizes[*returnSize] = numLen;// 增加返回结果的大小(*returnSize)++;// 递归结束,返回return;}// 遍历每个数字,尝试放入当前排列中for (int i = 0; i < numLen; i++) {// 如果该元素没有被使用if (used[i] == 0) {// 标记该元素已使用used[i] = 1;// 将该元素加入当前排列current[currentLen] = num[i];// 递归调用,继续选择下一个元素backtrack(num, numLen, result, returnSize, returnColumnSizes, current,currentLen + 1, used);// 回溯,撤销选择used[i] = 0;}}
}// permute函数,生成所有排列
int** permute(int* num, int numLen, int* returnSize, int** returnColumnSizes) {// num: 输入的数字数组// numLen: 数组的长度// returnSize: 当前已生成的排列数量// returnColumnSizes: 用于存储每个排列的列大小// 预分配空间,最多有10000个排列int** result = (int**)malloc(sizeof(int*) * 10000);// 预分配列大小空间*returnColumnSizes = (int*)malloc(sizeof(int) * 10000);// 初始化返回结果的大小为0*returnSize = 0;// 用于保存当前排列int* current = (int*)malloc(sizeof(int) * numLen);// 用于标记哪些元素已经使用,初始化为0int* used = (int*)calloc(numLen, sizeof(int));// 调用回溯生成排列backtrack(num, numLen, result, returnSize, *returnColumnSizes, current, 0,used);// 释放临时数组free(current);free(used);// 返回结果数组return result;
}

代码解释

  • backtrack 函数:核心回溯函数,递归生成所有排列。每次选择一个未使用的数字加入当前排列,递归调用直至当前排列长度达到输入数组的长度,完成一个排列的生成。

  • permute 函数:该函数初始化相关数据结构并调用回溯函数生成所有排列,返回排列的结果。

时间复杂度与空间复杂度分析

  • 时间复杂度:由于需要生成所有的排列,排列的个数为 n ! n! n!,每个排列的生成需要 O ( n ) O(n) O(n) 的时间。因此,整体时间复杂度为 O ( n ! ) O(n!) O(n!)

  • 空间复杂度:结果存储需要 O ( n ! ) O(n!) O(n!) 空间,递归调用栈深度最大为 O ( n ) O(n) O(n),所以整体空间复杂度为 O ( n ! ) O(n!) O(n!)

讨论

该方法通过回溯算法生成全排列,利用了递归和回溯的思想,适用于数据量较小(如 n ≤ 6 n \leq 6 n6)的问题。这题的参数量太多,非常容易搞混,挺令人烦恼的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/15475.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

力扣hot100刷题第一天

哈希 1. 两数之和 题目 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案&#xff0c;并且你不能使用两次相同的元素。你可以按任意…

Linux(CentOS)安装 Nginx

CentOS版本&#xff1a;CentOS 7 Nginx版本&#xff1a;1.24.0 两种安装方式&#xff1a; 一、通过 yum 安装&#xff0c;最简单&#xff0c;一键安装&#xff0c;全程无忧。 二、通过编译源码包安装&#xff0c;需具备配置相关操作。 最后附&#xff1a;设置 Nginx 服务开…

项目6:基于大数据校园一卡通数据分析和可视化

1、项目简介 本项目是基于大数据的清华校园卡数据分析系统&#xff0c;通过Hadoop&#xff0c;spark等技术处理校园卡交易、卡号和商户信息数据。系统实现消费类别、男女消费差异、学院消费排行和年级对比等分析&#xff0c;并通过Web后端和可视化前端展示结果。项目运行便捷&…

Django项目中创建app并快速上手(pycharm Windows)

1.打开终端 我选择的是第二个 2.运行命令 python manage.py startapp 名称 例如&#xff1a; python manage.py startapp app01 回车&#xff0c;等待一下&#xff0c;出现app01的文件夹说明创建成功 3.快速上手 1.app注册 增加一行 "app01.apps.App01Config"&#…

使用Docker + Ollama在Ubuntu中部署deepseek

1、安装docker 这里建议用docker来部署&#xff0c;方便简单 安装教程需要自己找详细的&#xff0c;会用到跳过 如果你没有安装 Docker&#xff0c;可以按照以下步骤安装&#xff1a; sudo apt update sudo apt install apt-transport-https ca-certificates curl software-p…

信创领域的PostgreSQL管理员认证

信创产业&#xff0c;全称为信息技术应用创新产业&#xff0c;是中国为应对国际技术竞争、保障信息安全、实现科技自立而重点发展的战略性新兴产业。其核心目标是通过自主研发和生态构建&#xff0c;逐步替代国外信息技术产品&#xff0c;形成自主可控的国产化信息技术体系。 发…

jemalloc的malloc案例来分析GOT表和PLT表有关流程

一、背景 在之前的博客 跟踪jemalloc 5.3.0的第一次malloc的源头原因及jemalloc相关初始化细节拓展-CSDN博客 里&#xff0c;我们分析了在preload jemalloc的库之后&#xff0c;main之前的一次malloc分配&#xff08;分配72704字节&#xff09;的源头原因并做了jemalloc的初始…

Centos Ollama + Deepseek-r1+Chatbox运行环境搭建

Centos Ollama Deepseek-r1Chatbox运行环境搭建 内容介绍下载ollama在Ollama运行DeepSeek-r1模型使用chatbox连接ollama api 内容介绍 你好&#xff01; 这篇文章简单讲述一下如何在linux环境搭建 Ollama Deepseek-r1。并在本地安装的Chatbox中进行远程调用 下载ollama 登…

使用sunshine和moonlight串流时的音频输出问题

设备&#xff1a;电脑和平板串流&#xff0c;把平板当副屏使用 1.如果启用安装steam音频驱动程序&#xff0c;则平板有声&#xff0c;电脑无声&#xff0c;在moonlight端可以设置平板和电脑同时发声&#xff0c;但是有点卡 2.只想电脑发声&#xff0c;平板无声 禁用安装steam…

微信小程序案例2——天气微信小程序(学会绑定数据)

文章目录 一、项目步骤1 创建一个weather项目2 进入index.wxml、index.js、index.wxss文件,清空所有内容,进入App.json,修改导航栏标题为“中国天气网”。3进入index.wxml,进行当天天气情况的界面布局,包括温度、最低温、最高温、天气情况、城市、星期、风行情况,代码如下…

如何在WPS和Word/Excel中直接使用DeepSeek功能

以下是将DeepSeek功能集成到WPS中的详细步骤&#xff0c;无需本地部署模型&#xff0c;直接通过官网连接使用&#xff1a;1. 下载并安装OfficeAI插件 &#xff08;1&#xff09;访问OfficeAI插件下载地址&#xff1a;OfficeAI助手 - 免费办公智能AI助手, AI写作&#xff0c;下载…

数字电路-基础逻辑门实验

基础逻辑门是数字电路设计的核心元件&#xff0c;它们执行的是基本的逻辑运算。通过这些基本运算&#xff0c;可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门&#xff08;AND&#xff09;、或门&#xff08;OR&#xff09;、非门&#xff08;NOT&#xff09;、异或门…

哪吒闹海!SCI算法+分解组合+四模型原创对比首发!SGMD-FATA-Transformer-LSTM多变量时序预测

哪吒闹海&#xff01;SCI算法分解组合四模型原创对比首发&#xff01;SGMD-FATA-Transformer-LSTM多变量时序预测 目录 哪吒闹海&#xff01;SCI算法分解组合四模型原创对比首发&#xff01;SGMD-FATA-Transformer-LSTM多变量时序预测效果一览基本介绍程序设计参考资料 效果一览…

C++,STL 迭代器简介:概念、分类、操作

文章目录 引言一、迭代器的基本概念1.1 什么是迭代器?1.2 迭代器的意义二、迭代器的分类2.1 示意图:迭代器能力层级2.2 示例:不同迭代器的操作三、迭代器的常用操作3.1 基本操作3.2 随机访问迭代器专用操作示例代码:随机访问迭代器四、迭代器的通用用法4.1 遍历容器4.2 配合…

EasyExcel 导出合并层级单元格

EasyExcel 导出合并层级单元格 一、案例 案例一 1.相同订单号单元格进行合并 合并结果 案例二 1.相同订单号的单元格进行合并2.相同订单号的总数和总金额进行合并 合并结果 案例三 1.相同订单号的单元格进行合并2.相同订单号的商品分类进行合并3.相同订单号的总数和总金额…

常用的python库-安装与使用

常用的python库函数 yield关键字openslide库openslide对象的常用属性 cv2库numpy库ASAP库-multiresolutionimageinterface库ASAP库的安装ASAP库的使用 concurrent.futures.ThreadPoolExecutorxml.etree.ElementTree库skimage库PIL.Image库 PIL.Image.Imagedetectron2库数据增强…

C++基础系列【8】如何解决编译器报的错误

博主介绍&#xff1a;程序喵大人 35- 资深C/C/Rust/Android/iOS客户端开发10年大厂工作经验嵌入式/人工智能/自动驾驶/音视频/游戏开发入门级选手《C20高级编程》《C23高级编程》等多本书籍著译者更多原创精品文章&#xff0c;首发gzh&#xff0c;见文末&#x1f447;&#x1f…

程序诗篇里的灵动笔触:指针绘就数据的梦幻蓝图<8>

大家好啊&#xff0c;我是小象٩(๑ω๑)۶ 我的博客&#xff1a;Xiao Xiangζั͡ޓއއ 很高兴见到大家&#xff0c;希望能够和大家一起交流学习&#xff0c;共同进步。 今天我们复习前面学习的指针知识 目录 关于指针数组和数组指针的区别指针数组&#xff08;Array of Poi…

UE5.5 PCGFrameWork--GPU CustomHLSL

在上一篇UE5.5 PCGFrameWork使用入门-CSDN博客 大致介绍了UE5 PCG框架的基本使用. 本篇探索PCGFrame的高级应用--GPU点云。也就是利用GPU HLSL编程对点云进行操纵&#xff0c;可以大幅度提升点云生成效率。 目前在UE5 PCG框架中&#xff0c;点云GPU的应用大致分为三类: Point…

Games202 Lecture11 LTC | Disney principled BRDF | NPR

Shading with microfacet BRDFs under polygonal lighting -Linearly Transformed Cosines(LTC)Real-Time PBR Materials cont. -Disney principled BRDFNon-photorealistic rendering(NPR) Linearly Transformed Cosines(LTC) lobe花瓣 BRDF的2d形状 基本思路: 任意BRDF变…