Maximum XOR of Two Numbers in an Array

题目
Given a non-empty array of numbers, a0, a1, a2, … , an-1, where 0 ≤ ai < 231.

Find the maximum result of ai XOR aj, where 0 ≤ i, j < n.

Could you do this in O(n) runtime?

答案

这题感觉像是利用xor性质的贪心算法
通过依次判断max的第31位, 第30位, ..., 第0位是否可以为1来实现。

class Solution {
    public int findMaximumXOR(int[] nums) {
        int mask = 0, max = 0;
        for(int i = 31; i >= 0; i--) {
            Set<Integer> set = new HashSet<>();
            mask = mask | (1 << i);
            for(int a : nums) {
                set.add(mask & a);
            }
            
            int temp_mask = max | (1 << i);
            for(int a : set) {
                int b = a ^ temp_mask;
                if(set.contains(b)) {
                    max = temp_mask;
                    break;
                }
            }
        }
        return max;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容