通过异或快速查找出现奇数次的单词
一个整型数组里除了2个单词之外,其他的单词都出现了偶数次。
请写程序找出这2个只出现一次的数字?
public static void main(String[] args) { String chars = "abcdefghijklmnopqrstuvwxyz"; int count = RandomUtils.nextInt(10000) + 1000; List<String> list = new ArrayList<String>(); for (int i = 0; i < count; i++) { String even = "X" + RandomStringUtils.random(9, chars); list.add(even); list.add(even); } String odd1 = "A" + RandomStringUtils.random(9, chars); String odd2 = "B" + RandomStringUtils.random(9, chars); list.add(RandomUtils.nextInt(list.size()), odd1); list.add(RandomUtils.nextInt(list.size()), odd2); List<String> results = find(list); System.out.println("第1个值: " + odd1); System.out.println("第2个值: " + odd2); System.out.println("计算结果: " + results); } private static List<String> find(List<String> list) { //1.第1轮找出异或结果 BitSet sum = BitSet.valueOf(list.get(0).getBytes()); for (int i = 1; i < list.size(); i++) { BitSet bits = BitSet.valueOf(list.get(i).getBytes()); sum.xor(bits);// sum xor= bits } BitSet mid = (BitSet) sum.clone(); //2.第2轮跟位为1的结果异或,得出其中1个结果 int nextSetBitIndex = mid.nextSetBit(0); for (String s : list) { BitSet bits = BitSet.valueOf(s.getBytes()); if (bits.size() > nextSetBitIndex && bits.get(nextSetBitIndex)) { mid.xor(bits);// mid xor= bits } } //2.第3轮跟第1个结果异或,得到第2个结果 sum.xor(mid); return Lists.newArrayList(new String(mid.toByteArray()), new String(sum.toByteArray())); }
运行结果:
第1个值: Azojacvjnv
第2个值: Bfonfasgkp
计算结果: [Bfonfasgkp, Azojacvjnv]