zoukankan      html  css  js  c++  java
  • 通过异或快速查找出现奇数次的单词

    一个整型数组里除了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]

  • 相关阅读:
    asp 后台批量管理程序
    面经
    单例模式(singleton)解析例子
    互联网产品经理必读书籍
    Struts2中的OGNL表达式
    阿里巴巴面经
    Servlet/JSP如何控制页面缓存于squid中
    Java陷阱一箩筐面试题集及解答
    阿里巴巴笔经http://bbs.yingjiesheng.com/forum.php?mod=viewthread&tid=696098&extra=page%3D1%26filter%3Dtypeid%26typeid%3D6356%26typeid%3D6356
    阿里巴巴java笔试
  • 原文地址:https://www.cnblogs.com/kong0it/p/5358596.html
Copyright © 2011-2022 走看看