【力扣:421,2935】数组内最大异或对问题

思路:从最高位向低位构造,对每一位利用哈希表寻找是否存在可使此位为1的数

第一轮找1:清空哈希表,1,2存1,到3发现1^0=1,res|=1<<3

第二轮找11:清空哈希表,1存10,2存10,3发现11^01=10,res|=1<<3

第三轮找111:清空哈希表,1存101,2存101,3存011...找不到能构造出111的

第四轮找1101:清空哈希表,1存1010,2存1011,到3发现1101^0111=1010,res|=(1<<0)

cpp 复制代码
class Solution {
public:
    int findMaximumXOR(vector<int>& nums) {
        int res=0,mask=0;
        unordered_set<int>set;
        for(int i=31;i>=0;i--){
            set.clear();
            mask|=1<<i;
            int tmp=res|(1<<i);
            for(int num:nums){
                int x=num&mask;
                if(set.contains(tmp^x)){
                    res=tmp;
                    break;
                }
                set.insert(x);
            }
        }
        return res;
    }
};

在前边基础上加上限制条件即可,对任意强数对满足|x-y|<=min(x,y),假设x比y大那么2*y>=x即可,那么只需要排序后利用unordered_map记录之前的值比较一下即可

cpp 复制代码
class Solution {
public:
    int maximumStrongPairXor(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        int res=0,mask=0;
        unordered_map<int,int>map;
        for(int i=31;i>=0;i--){
            map.clear();
            mask|=1<<i;
            int tmp=res|(1<<i);
            for(int j:nums){
                int x=mask&j;
                if(map.count(tmp^x)&&map[tmp^x]*2>=j){
                    res=tmp;
                    break;
                }
                map[x]=j;
            }
        }
        return res;
    }
};
相关推荐
KaMeidebaby4 分钟前
卡梅德生物技术快报|免疫共沉淀 - Co-IP 实验在转录因子 ATF3/Smad4 蛋白互作研究中的应用实例解析
网络·人工智能·网络协议·tcp/ip·其他·算法·新浪微博
wayz118 分钟前
20260530 软件ETF(159852)量化分析
算法·金融·数据分析·量化交易
旺仔老馒头.19 分钟前
【C++】类和对象(三)
开发语言·c++·程序人生·类和对象
Zklys19 分钟前
Cmake的学习笔记step1
c++·笔记·学习
zincsweet21 分钟前
C++ 实现进程池:主从架构、管道通信与任务调度
linux·c++
通信小呆呆23 分钟前
Hankel结构及其快速算法详解
线性代数·算法·机器学习
四代水门23 分钟前
服务端倒带(Server-Side Rewind)命中判定系统
java·前端·算法
吃好睡好便好25 分钟前
矩阵的左除和右除
人工智能·学习·线性代数·算法·矩阵
草莓熊Lotso27 分钟前
【CMake】静态库的编译、链接与引用全解析
linux·c语言·数据库·c++·软件工程·cmake
少司府29 分钟前
C++进阶:继承
c语言·开发语言·c++·继承·组合·虚继承