AcWing 143. 最大异或对——算法基础课题解

2024-05-29 12:20

本文主要是介绍AcWing 143. 最大异或对——算法基础课题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AcWing 143. 最大异或对

题目描述

在给定的 𝑁 个整数 𝐴1,𝐴2……𝐴𝑁 中选出两个进行 𝑥𝑜𝑟(异或)运算,得到的结果最大是多少?

输入格式

第一行输入一个整数 𝑁。

第二行输入 𝑁 个整数 𝐴1~𝐴𝑁。

输出格式

输出一个整数表示答案。

数据范围

1≤𝑁≤10^5,

0≤𝐴𝑖<2^31

输入样例

3
1 2 3

输出样例

3

C++

#include <iostream>using namespace std;const int N = 100010, M = N * 31;int n;
int a[N];
int son[M][2], idx;void insert(int x) {int p = 0;for (int i = 30; i >= 0; i--) {int u = x >> i & 1;if (!son[p][u]) son[p][u] = ++idx;p = son[p][u];}
}int query(int x) {int p = 0, res = 0;for (int i = 30; i >= 0; i--) {int u = x >> i & 1;if (son[p][!u]) {res += 1 << i;p = son[p][!u];} else {p = son[p][u];}}return res;
}int main() {ios::sync_with_stdio(false);cin.tie(nullptr);cin >> n;for (int i = 0; i < n; i++) cin >> a[i], insert(a[i]);int res = 0;for (int i = 0; i < n; i++) {int t = query(a[i]);res = max(res, t);}cout << res << endl;return 0;
}
#include <iostream>using namespace std;const int N = 100010, M = N * 31;int n;
int a[N];
int son[M][2], idx;void insert(int x) {int p = 0;for (int i = 30; i >= 0; i--) {int u = x >> i & 1;if (!son[p][u]) son[p][u] = ++idx;p = son[p][u];}
}int query(int x) {int p = 0, res = 0;for (int i = 30; i >= 0; i--) {int u = x >> i & 1;if (son[p][!u]) {p = son[p][!u];res = res * 2 + !u;} else {p = son[p][u];res = res * 2 + u;}}return res;
}int main() {ios::sync_with_stdio(false);cin.tie(nullptr);cin >> n;for (int i = 0; i < n; i++) cin >> a[i], insert(a[i]);int res = 0;for (int i = 0; i < n; i++) {int t = query(a[i]);res = max(res, a[i] ^ t);}cout << res << endl;return 0;
}

Go

package mainimport ("bufio""fmt""os"
)const (N = 100010M = N * 31
)var (n   inta   [N]intson [M][2]intidx int
)func insert(x int) {p := 0for i := 30; i >= 0; i-- {u := x >> i & 1if son[p][u] == 0 {idx++son[p][u] = idx}p = son[p][u]}
}func query(x int) int {p := 0res := 0for i := 30; i >= 0; i-- {u := x >> i & 1if son[p][1-u] != 0 {res += 1 << ip = son[p][1-u]} else {p = son[p][u]}}return res
}func main() {reader := bufio.NewReader(os.Stdin)writer := bufio.NewWriter(os.Stdout)defer writer.Flush()fmt.Fscan(reader, &n)for i := 0; i < n; i++ {fmt.Fscan(reader, &a[i])}res := 0for i := 0; i < n; i++ {insert(a[i])t := query(a[i])if t > res {res = t}}fmt.Fprintln(writer, res)
}
package mainimport ("bufio""fmt""os"
)const (N = 100010M = N * 31
)var (n   inta   [N]intson [M][2]intidx int
)func insert(x int) {p := 0for i := 30; i >= 0; i-- {u := x >> i & 1if son[p][u] == 0 {idx++son[p][u] = idx}p = son[p][u]}
}func query(x int) int {p := 0res := 0for i := 30; i >= 0; i-- {u := x >> i & 1if son[p][1-u] != 0 {res = res*2 + 1 - up = son[p][1-u]} else {res = res*2 + up = son[p][u]}}return res
}func main() {reader := bufio.NewReader(os.Stdin)writer := bufio.NewWriter(os.Stdout)defer writer.Flush()fmt.Fscan(reader, &n)for i := 0; i < n; i++ {fmt.Fscan(reader, &a[i])insert(a[i])}res := 0for i := 0; i < n; i++ {t := a[i] ^ query(a[i])if t > res {res = t}}fmt.Fprintln(writer, res)
}

这篇关于AcWing 143. 最大异或对——算法基础课题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1013642

相关文章

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键