JAVA求集合中的组合
好几个月没弄代码了,今天弄个求组合的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求集合中的组合的更多相关文章
- Java求字符串中出现次数最多的字符
Java求字符串中出现次数最多的字符 [尊重原创,转载请注明出处]http://blog.csdn.net/guyuealian/article/details/51933611 Java ...
- SQL_求集合中每天最大时间记录的总和
--问题求 集合中每天最大时间的总和 表中的数据 列: 用户 分数 时间 A 2 2014-01-01 01:00:00 A 2 2014-01-01 02:00:00 A 2 2014-01-01 ...
- Java 求字符串中出现频率最高字符
前段时间接触的这个题目,大体理解了,还有些小地方仍待进一步品味,暂且记下. import java.util.ArrayList; import java.util.Arrays; import ja ...
- Java Collection集合中的iterator方法
Iterator接口的概述 /** * java.util.Iterator接口:选代器(对集合进行遍历) * 有两个常用的方法 * boolean hasNext() * 如果仍有元素可以迭代,则返 ...
- Java 求集合的所有子集
递归方法调用,求解集合的所有子集. package ch01; import java.util.HashSet; import java.util.Iterator; import java.uti ...
- java List集合中contains方法总是返回false
ArrayList的contains方法 java 今天在用ArrayList类的caontains方法是遇到了问题,我写了一个存放User类的ArrayList 但在调用list.contains( ...
- Java:求字符串中邻接的数字为一个整体
public static void main(String[] args) { String strNumbers = "0123456789";//用来进行判断数字的 Syst ...
- JAVA 求数组中的最大值
package Code411;//求数组的最大值public class CodeArrayMax { public static void main(String[] args) { int ar ...
- [改善Java代码]集合中的元素必须做到compareTo和equals同步
实现了Comparable接口的元素就可以排序,
随机推荐
- Java 基础 Map 练习题
第一题 (Map)利用Map,完成下面的功能: 从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队.如果该 年没有举办世界杯,则输出:没有举办世界杯. 附:世界杯冠军以及对应的夺冠年 ...
- String高效编程优化(Java)
1, substring截取超大字符串可能造成的“内存泄漏” 2,+ 操作符的优化和局限 3,StringBuilder和StringBuffer 4,split和StringTokenizer做简单 ...
- 手机响应式js轮播基础
onmousedown --->ontuchstart onmousemove --->ontouchmove onmouseup --->ontouchend ontuchstar ...
- repeater留言板[转]
做了一个网站,其中的在线留言板块是用Repeater来显示留言的,这样可以用少的代码还实现多的功能,但是不知道怎么分页,要是留言过多就会使页面变的很长,能过查看众多网友的经验,知道用PagedData ...
- GZDBHelperDemo 一
1.新建Window窗体项目GZDBHelperDemo 2.从Nuget添加GZDBHelper引用 添加完成后会出现GZDBHelper的引用 3.添加数据库链接管理类 添加类库文件:Databa ...
- shell,bash,git bash,xshell,ssh
一:shell是linux/unix系统的外壳,也可以理解为命令行接口,就是你输入并执行命令行的地方.bash(born again shell)是shell的一种,最常用的shell之一.你在你的l ...
- 未能解析目标框架“.NETFramework,Version=v4.0”的 mscorlib的解决方法
本人菜鸟一个,在编码过程中遇到的问题记录下以备忘,高手别笑.最近在做一个项目,公司的VS版本是2010,家里的VS版本是2012.把公司的项目用2012打开后再用2010打开就出现 未能解析目标框架“ ...
- ubuntu12.04 安装 QQ
友情提示:QQ对于第三方平台封杀已经到了丧心病狂的程度,所以不要妄想在linux的QQ能像win系统下的效果,只能祈求能用就好 1.下载QQ安装包 http://pan.baidu.com/s/1ge ...
- 基础笔记10(IO 1.7try-with-resource) 装饰模式
1.读写的类型分为字节流和字符流,字节流一般是视频音频其他所有的类型都可以. (非文档文件使用字符流易造成未知编码(?)错误) InputStream OutputStream 抽象类 fileInp ...
- VERY DEEP CONVOLUTIONAL NETWORKS FOR LARGE-SCALE IMAGE RECOGNITION 这篇论文
由Andrew Zisserman 教授主导的 VGG 的 ILSVRC 的大赛中的卷积神经网络取得了很好的成绩,这篇文章详细说明了网络相关事宜. 文章主要干了点什么事呢?它就是在在用卷积神经网络下, ...