[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;
            }
        }
        
    }
};

 

提供了一个基于51单片机的RFID门禁系统的完整资源文件,包括PCB图、原理图、论文以及源程序。该系统设计由单片机、RFID-RC522频射卡模块、LCD显示、灯控电路、蜂鸣器报警电路、存储模块和按键组成。系统支持通过密码和刷卡两种方式进行门禁控制,灯亮表示开门成功,蜂鸣器响表示开门失败。 资源内容 PCB图:包含系统的PCB设计图,方便用户进行硬件电路的制作和调试。 原理图:详细展示了系统的电路连接和模块布局,帮助用户理解系统的工作原理。 论文:提供了系统的详细设计思路、实现方法以及测试结果,适合学习和研究使用。 源程序:包含系统的全部源代码,用户可以根据需要进行修改和优化。 系统功能 刷卡开门:用户可以通过刷RFID卡进行门禁控制,系统会自动识别卡片并判断是否允许开门。 密码开门:用户可以通过输入预设密码进行门禁控制,系统会验证密码的正确性。 状态显示:系统通过LCD显示屏显示当前状态,如刷卡成功、密码错误等。 灯光提示:灯亮表示开门成功,灯灭表示开门失败或未操作。 蜂鸣器报警:当刷卡或密码输入错误时,蜂鸣器会发出报警声,提示用户操作失败。 适用人群 电子工程、自动化等相关专业的学生和研究人员。 对单片机和RFID技术感兴趣的爱好者。 需要开发类似门禁系统的工程师和开发者。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值