通过异或快速查找出现奇数次的单词

本文介绍了一种使用BitSet和异或操作的独特算法,该算法能在含有大量重复单词的数组中找到仅出现一次的两个单词。通过两轮异或操作,算法巧妙地解决了问题,最后返回这两个唯一的单词。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

转载于:https://www.cnblogs.com/kong0it/p/5358596.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值