好几个月没弄代码了,今天弄个求组合的DEMO

思路是将集合的每个值对照一个索引,索引大小是集合的大小+2.索引默认为[000...000],当组合后选取的组合值demo为[0100..00]。然后根据遍历索引来到集合中取值。

上代码:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; public class ComBit { public static void main(String[] args) {
// Integer test
int[] combination = new int[] { 1, 2, 3, 4 };
List<Integer> combinationlist = new ArrayList<Integer>();
for (Integer integer : combination) {
combinationlist.add(integer);
}
ComBitIterator<Integer> i = new ComBitIterator<Integer>(combinationlist);
while (i.hasNext()) {
Object obj = i.next();
System.out.println(obj.toString());
}
// String test
String[] str = new String[] { "apple", "orange", "tomato", "potato" };
List<String> combinationSlist = new ArrayList<String>();
for (String s : str) {
combinationSlist.add(s);
}
ComBitIterator<String> ii = new ComBitIterator<String>(combinationSlist);
while (ii.hasNext()) {
Object obj = ii.next();
System.out.println(obj.toString());
} } } class ComBitIterator<T> implements Iterator<T> { private int[] _bitArray = null; protected final int _length; protected final List<T> combination; protected List<T> _currentSet; public ComBitIterator(List<T> combination) {
_currentSet = new ArrayList<T>();
this._length = combination.size();
this._bitArray = new int[_length + 2];
this.combination = combination;
} @Override
public boolean hasNext() {
return _bitArray[_length + 1] != 1;
} @SuppressWarnings("unchecked")
@Override
public T next() {
_currentSet.clear();
for (int index = 1; index <= _length; index++) {
if (_bitArray[index] == 1) {
T value = combination.get(index - 1);
_currentSet.add(value);
}
}
int i = 1;
while (_bitArray[i] == 1) {
_bitArray[i] = 0;
i++;
}
_bitArray[i] = 1;
return (T) _currentSet;
} }

------------------------------------------------分割线---------------------------------------------------------

PS:代码源于要求求数字1-20中 任取N的组合后合值为36,于是思路想到两种,第一种是递归,第二种虽然也是递归,但是想弄个通用的,就有了以上的代码。另外群里有人写出了直接递归的代码,也附上:

public static void main(String[] args) {
combinateDataOfRange(1, 20, 36);
} public static void combinateDataOfRange(int min, int max, int target) {
combinateData(0, min, max, target, new Stack<Integer>());
} public static void combinateData(int sum, int min, int max, int target,
Stack<Integer> stack) {
for (int i = stack.isEmpty() ? min : (Integer) stack.lastElement() + 1; i < max; ++i) {
int tempSum = sum + i;
stack.push(i);
if (tempSum == target) {
System.out.println(stack + "=" + target);
} else {
combinateData(tempSum, min, max, target, stack);
}
stack.pop();
}
}

JAVA求集合中的组合的更多相关文章

  1. Java求字符串中出现次数最多的字符

    Java求字符串中出现次数最多的字符  [尊重原创,转载请注明出处]http://blog.csdn.net/guyuealian/article/details/51933611      Java ...

  2. SQL_求集合中每天最大时间记录的总和

    --问题求 集合中每天最大时间的总和 表中的数据 列: 用户 分数 时间 A 2 2014-01-01 01:00:00 A 2 2014-01-01 02:00:00 A 2 2014-01-01 ...

  3. Java 求字符串中出现频率最高字符

    前段时间接触的这个题目,大体理解了,还有些小地方仍待进一步品味,暂且记下. import java.util.ArrayList; import java.util.Arrays; import ja ...

  4. Java Collection集合中的iterator方法

    Iterator接口的概述 /** * java.util.Iterator接口:选代器(对集合进行遍历) * 有两个常用的方法 * boolean hasNext() * 如果仍有元素可以迭代,则返 ...

  5. Java 求集合的所有子集

    递归方法调用,求解集合的所有子集. package ch01; import java.util.HashSet; import java.util.Iterator; import java.uti ...

  6. java List集合中contains方法总是返回false

    ArrayList的contains方法 java 今天在用ArrayList类的caontains方法是遇到了问题,我写了一个存放User类的ArrayList 但在调用list.contains( ...

  7. Java:求字符串中邻接的数字为一个整体

    public static void main(String[] args) { String strNumbers = "0123456789";//用来进行判断数字的 Syst ...

  8. JAVA 求数组中的最大值

    package Code411;//求数组的最大值public class CodeArrayMax { public static void main(String[] args) { int ar ...

  9. [改善Java代码]集合中的元素必须做到compareTo和equals同步

    实现了Comparable接口的元素就可以排序,

随机推荐

  1. HTML5:web socket 和 web worker

    a:hover { cursor: pointer } 做练习遇到了一个选择题,是关于web worker的,问web worker会不会影响页面性能?补习功课之后,答案是不会影响. 查阅了相关资料学 ...

  2. [TCPIP] DNS Note

    TCPIP DNS  域名系统 DNS 是一个应用于TCP/IP应用程序的分布式数据库,它提供主机名字和IP地址之间的转换及有关电子邮件的选路信息. 对DNS的访问是通过一个地址解析器来完成的,在Un ...

  3. ISPA

    来自CSDN的Rachel Zhang 4. Improved SAP 算法 本次介绍的重头戏.通常的 SAP 类算法在寻找增广路时总要先进行 BFS,BFS 的最坏情况下复杂度为 O(E),这样使得 ...

  4. 对线程等待函数pthread_join二级指针参数分析

    分析之前先搞明白,这个二级指针其实在函数内部是承接了上个线程的返回值. 看man手册,发现返回值是个普通指针.人家用二级指针来承接,可能准备干大事.这个可以自己搜索一下.原因嘛,二级指针是保存了这个地 ...

  5. node.js + expres 的安装

    一 windows下安装 首先去官网下载msi安装包. 两篇很有参考价值的文章: http://cnodejs.org/topic/4fae80c02e8fb5bc650a8360 http://bl ...

  6. MACS2 安装与使用

    1)下载MACS2 下载网址: https://pypi.python.org/pypi/MACS2 (有下载网址和安装.使用示例)   $ python setup.py install出现如下问题 ...

  7. MS SQL-Server快捷键

    快捷键                    功能 Ctrl+Shift+B          生成解决方案 Ctrl+F7                  生成编译 Ctrl+O          ...

  8. php : 基础(4)

    流程控制 循环结构 循环的中断 循环中,有两种中断语句可以使用: break: 用于完全终止某个循环,让执行流程进入到循环语句后面的语句: continue: 用于停止当前正在进行的当次循环,而进入到 ...

  9. 解决httpServletRequest.getParameter获取不到参数

    用httpServletRequest.getParameter接收post请求参数,发送端content Type必须设置为application/x-www-form-urlencoded:否则会 ...

  10. 转:如何向妻子解释OOD

    如何向妻子解释OOD 前言 此文译自CodeProject上<How I explained OOD to my wife>一文,该文章在Top Articles上排名第3,读了之后觉得非 ...