【全排列 - 递归】
2016-03-28 20:07
399 查看
#include<stdio.h> #include<stdlib.h> #include<iostream> using namespace std; int total = 0; void perm(int num[],int k,int m) { if(k == m-1) { for(int i = 0;i < m;i++) printf("%d ",num[i]); printf("\n"); total++; } else { for(int i = k;i < m;i++) { swap(num[k],num[i]); perm(num,k+1,m); swap(num[k],num[i]); } } } int main() { int num[100],n; scanf("%d",&n); for(int i = 0;i < n;i++) num[i] = i+1; perm(num,0,n); printf("排列总数:%d\n",total); return 0; }
相关文章推荐
- Linux C函数参考手册(PDF版)
- C# partial关键字说明
- Lua教程(十七):C API简介
- 简单谈谈lua和c的交互
- C#中的委托数据类型简介
- C#编写的艺术字类实例代码
- C#实现打造气泡屏幕保护效果
- 举例讲解C#编程中委托的实例化使用
- 使用C#代码获取存储过程返回值
- C/C++数据对齐详细解析
- 利用C语言来求最大连续子序列乘积的方法
- 字符串的组合算法问题的C语言实现攻略
- C 语言基础教程(我的C之旅开始了)[三]
- 学习C和C++的9点经验总结
- C++中的extern “C”用法详解
- C 语言基础教程(我的C之旅开始了)[七]
- 最大子矩阵问题实例解析
- C字符串操作函数实现方法小结
- C语言中static的作用及C语言中使用静态函数有何好处