数组全排列算法(二)整型数组全排列——递归算法
来源:互联网 发布:json改为json数组 编辑:程序博客网 时间:2024/05/15 14:34
算法题:实现一个整型数组的全排列,
void perm(int list[], int k, int m)
参数说明:list,数组;k开始位置,m个数。
用递归算法实现代码如下:
void perm(int list[], int k, int m){ if ( k==m ) { copy(list,list+m,ostream_iterator<int>(cout," ")); cout<<endl; return; } for (int i=k; i<m; i++)// 注意这里不是for (int i=k; i<=m; i++),否则会出现乱数据。 { swap(list[k],list[i]);perm(list,k+1,m); swap(list[k],list[i]); }}
int main() { int List[] = {1,2,3} ;perm(List, 0, sizeof(List)/sizeof(int));return 0; }
测试结果:
当list是 {1,2,3,4} 时,
1 2 3 4
1 2 4 3
1 3 2 4
1 3 4 2
1 4 3 2
1 4 2 3
2 1 3 4
2 1 4 3
2 3 1 4
2 3 4 1
2 4 3 1
2 4 1 3
3 2 1 4
3 2 4 1
3 1 2 4
3 1 4 2
3 4 1 2
3 4 2 1
4 2 3 1
4 2 1 3
4 3 2 1
4 3 1 2
4 1 3 2
4 1 2 3
当list是 {1,2,3} 时
1 2 3
1 3 2
2 1 3
2 3 1
3 2 1
3 1 2
转载请注明原创链接:http://blog.csdn.net/wujunokay/article/details/11894667
- 数组全排列算法(二)整型数组全排列——递归算法
- 数组全排列算法(一)字符串数组全排列——逐个追加组合算法
- 数组的全排列算法
- 全排列算法(递归)
- 全排列算法(递归)
- 全排列递归算法
- 全排列递归算法
- 全排列算法-递归
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 全排列递归算法
- 递归算法---全排列
- 全排列递归算法
- 我收藏的重要站点
- 浅析C++重载覆盖隐藏以及虚函数
- 对自我的总结
- Linux shell编程 1 ---- shell脚本编程基础
- 使用PL/SQL Developer远程连接到oracle 11g
- 数组全排列算法(二)整型数组全排列——递归算法
- jsp之session对象
- 使用HTML5技术开发的超酷颜色选择器
- 带索引的mapReduce
- BNU1064:人品问题
- LoadRunner 使用IP欺骗
- 带索引的HIVE
- NX(UGS)技术关于我和你顶着忽移不定的云彩
- 【LeetCode】Triangle做题笔记