Codeup_5972:问题 A: 【递归入门】全排列

2024-03-24 16:20

本文主要是介绍Codeup_5972:问题 A: 【递归入门】全排列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • Problem Description
  • Input
  • Output
  • Sample Input
  • Sample Output
  • 原题链接
  • 解题思路
  • 经验总结
  • 代码实现(C)

Problem Description

排列与组合是常用的数学方法。
先给一个正整数 ( 1 < = n < = 10 )
例如n=3,所有组合,并且按字典序输出:
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

Input

输入一个整数n( 1 <= n <= 10)

Output

输出所有全排列
每个全排列一行,相邻两个数用空格隔开(最后一个数后面没有空格)

Sample Input

3

Sample Output

1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

原题链接

  • Codeup_5972:问题 A: 【递归入门】全排列

解题思路

  1. 用深度优先搜索遍历所有排列方案,n个数对应n个位置。
  2. 用int型数组ans记录已选择数的位置(即全排列方案),用bool型数组visit记录某个数是否被选择。
  3. int类型变量count记录当前已经选择数字的个数,当已选数字个数为n时,表示已经形成全排列(递归边界)。
  4. 从第一个位置开始,遍历所有数字(1 ≤ i ≤ n),对每个数字i,有两条路,选择or不选择。
    1. 选择:将当前数字i加入全排列数组ans中,并设为已访问,考虑下一个位置(即count + 1)。
    2. 不选择:考虑下一个数字(即i+1)。

经验总结

  1. 当count == n时,表示已形成全排列,此时dfs应当返回。
  2. 但由于visit数组的存在,此处也可以不返回,因为[1,n]范围内的数均被访问过,dfs中的选择过程不会选择任何数。

代码实现(C)

#include <stdio.h>
#include <stdbool.h>
#include <string.h>#define MaxSize 11int n;
bool visit[MaxSize];    // 记录数字是否被访问过
int ans[MaxSize];       // 记录全排列方案// 打印全排列
void print() {for (int i = 0; i < n; ++i) {if (i < n - 1)printf("%d ", ans[i]);elseprintf("%d\n", ans[i]);}
}// 每进行一次DFS,选择一个数字,count记录当前已选择数字的个数
void DFS(int count) {if (count == n) {               // 递归边界:已经选择了n个数print();                    // 打印全排列return;}for (int i = 1; i <= n; ++i) {  // 选择1~n范围内的数字if (!visit[i]) {            // 如果i没被选过ans[count] = i;         // 选择i,加入全排列visit[i] = true;        // 设置i已被访问DFS(count + 1);     	// 继续选择下一个数字// 执行到这说明选择i的路已经走完,该走不选i的路线了(i++)visit[i] = false;       // 设置i未被访问}}}int main() {while (~scanf("%d", &n)) {// 初始化memset(visit, false, sizeof(visit));// 初始时选择了0个数DFS(0);}return 0;
}

这篇关于Codeup_5972:问题 A: 【递归入门】全排列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/842123

相关文章

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

关于Nginx跨域问题及解决方案(CORS)

《关于Nginx跨域问题及解决方案(CORS)》文章主要介绍了跨域资源共享(CORS)机制及其在现代Web开发中的重要性,通过Nginx,可以简单地解决跨域问题,适合新手学习和应用,文章详细讲解了CO... 目录一、概述二、什么是 CORS?三、常见的跨域场景四、Nginx 如何解决 CORS 问题?五、基

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss