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

相关文章

解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题

《解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:org.junit.Test问题》:本文主要介绍解决tomcat启动时报Junit相... 目录tomcat启动时报Junit相关错误Java.lang.ClassNotFoundException

解决Maven项目报错:failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题

《解决Maven项目报错:failedtoexecutegoalorg.apache.maven.plugins:maven-compiler-plugin:3.13.0的问题》这篇文章主要介... 目录Maven项目报错:failed to execute goal org.apache.maven.pl

MySQL主从同步延迟问题的全面解决方案

《MySQL主从同步延迟问题的全面解决方案》MySQL主从同步延迟是分布式数据库系统中的常见问题,会导致从库读取到过期数据,影响业务一致性,下面我将深入分析延迟原因并提供多层次的解决方案,需要的朋友可... 目录一、同步延迟原因深度分析1.1 主从复制原理回顾1.2 延迟产生的关键环节二、实时监控与诊断方案

SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法

《SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法》在SQLyog中执行存储过程时出现的前置缩进问题,实际上反映了SQLyog对SQL语句解析的一个特殊行为,本文给大家介绍了详... 目录问题根源正确写法示例永久解决方案为什么命令行不受影响?最佳实践建议问题根源SQLyog的语句分

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊