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

相关文章

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM