[LeetCode] (medium) 421. Maximum XOR of Two Numbers in an Array

https://leetcode.com/problems/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 ≤ ij < n.

Could you do this in O(n) runtime?

Example:

Input: [3, 10, 5, 25, 2, 8]
Output: 28
Explanation: The maximum result is 5 ^ 25 = 28.

字典树:

 

class Solution {
public:
    struct Node{
        Node* zero;
        Node* one;
    
        Node():zero(NULL), one(NULL){};
    };
    
    Node* root = new Node();
    
    int findMaximumXOR(vector<int>& nums) {
        int result = 0;
        if(nums.size() < 2) return result;
        if(nums.size() == 2) return nums[0]^nums[1];
        
        
        Node* cur_node;
        
        add_num(nums[0]);
        
        for(int i = 1; i < nums.size(); ++i){
            int cur = nums[i];
            int tem = compare_exist(cur);
            // cout << tem << endl;
            
            result = max(result, tem);
            add_num(cur);
        }
        
        return result;
    }
    
    int compare_exist(int num){
        Node* cur = root;
        int result = 0;
        
        for(int i = (1 << 30); i > 0; i >>= 1){
            if(num & i){
                if(cur->zero != NULL){
                    result |= i;
                    cur = cur->zero;
                }else{
                    cur = cur->one;
                }
            }else{
                if(cur->one != NULL){
                    result |= i;
                    cur = cur->one;
                }else{
                    cur = cur->zero;
                }
            }
        }
        
        return result;
    }
    
    void add_num(int num){
        Node* cur = root;
        
        for(int i = (1 << 30); i > 0; i >>= 1){
            if(num & i){
                if(cur->one == NULL) cur->one = new Node();
                cur = cur->one;
            }else{
                if(cur->zero == NULL) cur->zero = new Node();
                cur = cur->zero;
            }
        }
        
    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值