本文实例讲述了Java基于递归解决全排列问题算法。分享给大家供大家参考,具体如下:
排列问题
设R={r1,r2,...,rn}是要进行排列的n个元素,Ri=R-{ri}。集合x中元素的全排列记为Perm(X)。(ri)Perm(X)表示在全排列Perm(X)的每一个排列前加上前缀ri得到的排列。R的全排列可归纳如下:
当n=1时,Perm(R)=(r),其中r是集合中唯一的元素;
当n>1时,Perm(R)由(r1)Perm(R1),(r2)Perm(R2),(r3)Perm(R3)。。。。(rn)Perm(Rn)构成。
public class AllSort { public static void perm(int[] list, int k, int m) { if( k == m) { for (int i = 0; i <=m; i++) { System.out.print(list[i]); } System.out.println(); } else{ for(int i = k; i <= m; i++) { swap(list,k,i); perm(list, k+1 , m); swap(list,k,i); } } } public static void swap(int[] list, int a, int b) { int temp; temp = list[a]; list[a] = list[b]; list[b] = temp; } public static void main(String args[]) { int[] list = new int[5]; for(int i = 0; i < list.length; i++) { list[i] = i+1; } perm(list,0,list.length-1); }}
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数260
191.63 KB下载数245
143.91 KB下载数1139
183.71 KB下载数640
644.84 KB下载数2752
相关文章
发现更多好内容猜你喜欢
AI推送时光机Java基于递归解决全排列问题算法示例
后端开发2023-05-30
java基于递归算法实现汉诺塔问题实例
后端开发2023-05-31
Java基于循环递归回溯实现八皇后问题算法示例
后端开发2023-05-31
基于Java语言的递归运算例题详解
后端开发2022-11-13
基于Java递归算法的封装解决方法是什么
后端开发2023-06-02
Python基于贪心算法解决背包问题示例
后端开发2022-06-04
Java回溯法解决全排列问题流程详解
后端开发2024-04-02
C++回溯算法中的全排列问题怎么解决
后端开发2023-07-05
Java基于分治算法实现的棋盘覆盖问题示例
后端开发2023-05-30
Java通过递归算法解决迷宫与汉诺塔及八皇后问题
后端开发2024-04-02
Java怎么通过递归算法解决迷宫与汉诺塔及八皇后问题
后端开发2023-06-30
java编程经典案例之基于斐波那契数列解决兔子问题实例
后端开发2023-05-30
Java使用贪心算法解决电台覆盖问题(示例详解)
后端开发2024-04-02
java基于双向环形链表解决丢手帕问题的示例分析
后端开发2023-05-30
java暴力匹配及KMP算法解决字符串匹配问题示例详解
后端开发2024-04-02
咦!没有更多了?去看看其它编程学习网 内容吧