遍历数组所有组合的方法有两种:使用迭代法,通过组合工具类递归生成组合。使用递归法,通过递归函数生成组合,并打印组合内容。

如何遍历数组的所有组合(Java)
遍历数组所有组合的方法有两种:
方法 1:使用迭代法
阿里云-虚拟数字人
阿里云-虚拟数字人是什么? …
2 查看详情
// arr[] 为要组合的数组// n 为数组的长度// r 为组合的元素个数public static void combination(int[] arr, int n, int r) { int[] data = new int[r]; combinationUtil(arr, data, 0, n - 1, 0, r);}private static void combinationUtil(int[] arr, int[] data, int start, int end, int index, int r) { if (index == r) { for (int j = 0; j < r; j++) { System.out.print(data[j] + " "); } System.out.println(); return; } for (int i = start; i = r - index; i++) { data[index] = arr[i]; combinationUtil(arr, data, i + 1, end, index + 1, r); }}
方法 2:使用递归法
立即学习“Java免费学习笔记(深入)”;
// arr[] 为要组合的数组// n 为数组的长度// r 为组合的元素个数public static void combination(int[] arr, int n, int r) { // 创建一个空的集合来存储组合 List combination = new ArrayList(); // 调用递归函数来生成组合 combinationUtil(arr, combination, 0, n, r);}private static void combinationUtil(int[] arr, List combination, int start, int n, int r) { // 如果已经选择到 r 个元素,则打印组合 if (combination.size() == r) { System.out.println(combination); return; } // 从 start 到 n-1 遍历数组中的每个元素 for (int i = start; i < n; i++) { // 将当前元素添加到组合中 combination.add(arr[i]); // 递归生成剩余的组合 combinationUtil(arr, combination, i + 1, n, r); // 从组合中移除当前元素 combination.remove(combination.size() - 1); }}
以上就是怎么遍历数组的所有组合java的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/428569.html
微信扫一扫
支付宝扫一扫