leetcode_421数组中两个数的最大异或值

2023-11-06 03:52

本文主要是介绍leetcode_421数组中两个数的最大异或值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 题意

求数组中两个数的最大异或值

数组中两个数的最大异或值

2. 题解

2.1 哈希表

a i ⊕ a j = x a_i \oplus a_j = x aiaj=x
所以
a i = x ⊕ a j a_i =x \oplus a_j ai=xaj

考虑 a i 、 a j a_i、a_j aiaj的每一位的所有情况

b i t ( a i , k ) bit(a_i,k) bit(ai,k) b i t ( a j , k ) bit(a_j,k) bit(aj,k) b i t ( x , k ) bit(x,k) bit(x,k)
000
011
101
110

我们可以从最高位开始尝试,是否能使第 k k k位为1。

即对 p r e ( k , a j ) pre(k,a_j) pre(k,aj) p r e S e t ( k ) preSet(k) preSet(k)中是否有 x ⊕ p r e ( k , a j ) x \oplus pre(k,a_j) xpre(k,aj)使得枚举的最大前缀 x x x成立。

  • 代码
class Solution {
public:int findMaximumXOR(vector<int>& nums) {int ans = 0;for ( int i = 30; i > -1; --i ) {unordered_set<int> preSet;for ( int num: nums) {preSet.insert( num >> i);}ans = ans << 1 | 1;bool find = false;for (int num: nums) {if ( preSet.count( (num >> i) ^ ans )) {find = true;break;}}if ( !find)ans--;}     return ans;}
};
2.2 前缀树

可以将所有值插入到一颗0-1前缀树中,然后再遍历每个值,对于每一位尽量选择它的翻转值,如果
树中有该路径的话。最后再取最大值。

class Solution {
public:class Trie {public:Trie():isEnd(false),left(nullptr),right(nullptr){}void insert(int v) {Trie *cur = this;for ( int bit = 30; bit > -1; --bit) {int c = (1 << bit) & v;if (!c) {if (cur->left == nullptr) {cur->left = new Trie();}cur = cur->left;}else {if ( cur->right == nullptr)cur->right = new Trie();cur = cur->right;}}cur->isEnd = true;}int getMaxXor(int v) {int ans = 0;Trie *cur = this;for ( int bit = 30; bit > -1; --bit) {int c = (1 << bit) & v;if (c) {if ( cur->left) {cur = cur->left;ans |= (1 << bit);}else {cur = cur->right;}}else {if ( cur->right ) {cur  = cur->right;ans |= (1 << bit);}else {cur = cur->left;}}}return ans; }private:Trie *left;Trie *right;bool isEnd;};int findMaximumXOR(vector<int>& nums) {Trie trie;for (int num: nums)trie.insert(num);int ans = 0;for (int num:nums) {ans = max(ans, trie.getMaxXor(num) );}return ans;}
};

这篇关于leetcode_421数组中两个数的最大异或值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/354322

相关文章

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序