【力扣: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;
    }
};
相关推荐
hsjkdhs4 分钟前
C++之多层继承、多源继承、菱形继承
开发语言·c++·算法
立志成为大牛的小牛26 分钟前
数据结构——十七、线索二叉树找前驱与后继(王道408)
数据结构·笔记·学习·程序人生·考研·算法
星空下的曙光28 分钟前
Node.js crypto模块所有 API 详解 + 常用 API + 使用场景
算法·node.js·哈希算法
阳光雨滴42 分钟前
使用wpf用户控件编程落石效果动画
c++·wpf
小贾要学习1 小时前
【数据结构】C++实现红黑树
数据结构·c++
ajassi20002 小时前
开源 C++ QT QML 开发(十七)进程--LocalSocket
c++·qt·开源
StarPrayers.2 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
微露清风2 小时前
系统性学习C++-第五讲-内存管理
java·c++·学习
爱吃橘的橘猫2 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
235162 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展