java全组合算法
2016-10-14 13:41
99 查看
public static void combination(int[] s) { if (s.length == 0) { return; } int len = s.length; int n = 1 << len; // 从1循环到2^len-1 for (int i = 1; i < n; i++) { StringBuffer sb = new StringBuffer(); // 查看第一层循环里面的任意一种取值当中的哪一位是1[比如ab,011], 如果是1,对应的字符就存在,打印当前组合。 int sum = 0; for (int j = 0; j < len; j++) { if ((i & (1 << j)) != 0) { // 对应位上为1,则输出对应的字符 int a = s[j]; sum = sum + a; sb.append(s[j]); } } System.out.println("组合:" + sb + " ,sum:" + sum); } }
https://segmentfault.com/a/1190000002710424
相关文章推荐
- 用改过的“数字进制转换”枚举字符组合,这是简化的版本。(java,算法研究)
- 高效率的排列组合算法(java实现)
- Java编程算法基础----组合数学实践
- JAVA-- M选N的组合算法
- java算法之字符组合排序
- 【转】JAVA实现排列组合算法
- 排列组合算法之二: 01转换法_java改变后的c++改进版
- 高效率的全组合算法(Java版实现)
- 针对较大基数的排列组合算法Java实现类(n选m)
- Java实现通用组合算法
- 排列组合算法 的java实现
- Java实现通用组合算法
- Java实现基于数值编码原理的组合算法(单线程)
- JAVA-- M选N的组合算法
- java 高效率的排列组合算法(java实现)
- 还是字符组合问题,直接针对题目建模(java,算法探讨)
- Java实现基于数值编码原理的组合算法(多线程)
- 简述Java程序语言通用组合算法的实现
- java排列组合算法代码实现
- 排列组合算法之一: 01转换法_java改变后的c++版