Chip Factory HDU - 5536 长春站 字典树

传送门

题目大意:给一个有n个数的数列, 从这个数列中取三个数(不能是同一个数), 使两个数和与另一个数异或。 求所有组合中的最大值。即  max( (s[i] + s[j]) ^ s[k])   i, j, k ∈(1~n);

解题思路:听说漂亮的暴力可以过·······

  我还是用字典树吧···, 首先呢, 我们枚举i, j; 然后在字典树上搜索有没有一个数可以使他俩的和异或之后最大。

代码:

#include <iostream>
#include <cstdio>

using namespace std;

const int maxn = 1000050;
int tot = 1, root = 1;
int A[10000];
struct Tree
{
	int ch[2], size;
}T[maxn];

void init()
{
	for(int i=0; i<maxn; i++)
		T[i].size = T[i].ch[0] = T[i].ch[1] = 0;
}

void Insert(int x)
{
	int p = root;
	int t;
	T[p].size++;
	for(int i=30; i >= 0; --i)
	{
		if(x & (1 << i)) t = 1;
		else t = 0;
		if(T[p].ch[t] == 0)	T[p].ch[t] = ++tot;
		p = T[p].ch[t];
		T[p].size++;
	}
}

void Delete(int x)
{
	int p = root;
	T[p].size--;
	int t;
	for(int i=30; i>=0; --i)
	{
		if(x & (1 << i)) t = 1;
		else t = 0;
		p = T[p].ch[t];
		T[p].size--;
	}
}


int Query(int x)
{
	int p = root;
	int t;
	for(int i=30; i >= 0; --i)
	{
		if(x & (1 << i)) t = 1;
		else t = 0;

		if(t)
		{
			if(T[p].ch[0] && T[T[p].ch[0]].size > 0) p = T[p].ch[0];
			else
			{
				x ^= (1 << i);
				p = T[p].ch[1];
			}
		}
		else 
		{
			if(T[p].ch[1] && T[T[p].ch[1]].size > 0) {p = T[p].ch[1]; x ^= (1 << i);}
			else 
			{
				p = T[p].ch[0];
			}
		}
	}
	return x;
}


int main()
{
	int Case;
	scanf("%d", &Case);
	while(Case--)
	{
		init();
		int n, ans = 0;
		scanf("%d", &n);
		for(int i=0; i<n; i++)
		{
			scanf("%d", &A[i]);
			Insert(A[i]);
		}
		for(int i=0; i<n; i++)
		{
			Delete(A[i]);
			for(int j=i+1; j<n; j++)
			{
				Delete(A[j]);
				ans = max(ans, Query(A[i] + A[j]));
				Insert(A[j]);
			}
			Insert(A[i]);
		}
		printf("%d\n", ans);
	}	

	return 0;
}


基于STM32的循迹避障小车资料源码(高分项目),个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(
内容概要:本文详细介绍了SSM框架(Spring、SpringMVC、MyBatis)的相关知识,涵盖Maven项目管理工具、前端开发技术、HTTP协议及Tomcat服务器等内容。文章首先讲解了SSM框架的组成,包括Spring的IOC、DI、AOP等功能,SpringMVC的请求处理流程以及MyBatis的数据操作。接着介绍了Maven作为项目管理工具的作用,如依赖管理和项目构建,并详细描述了Maven的配置文件pom.xml的使用方法。此外,还探讨了HTTP协议的特点、请求响应格式,以及Web服务器Tomcat的基本概念和工作原理。最后,文章对前端开发技术进行了概述,包括HTML、CSS、JavaScript等基础知识,并简要介绍了Ajax技术。 适合人群:具备一定编程基础,特别是Java开发经验的研发人员,尤其是那些正在学习或使用SSM框架进行Web开发的工程师。 使用场景及目标:①理解SSM框架的工作原理及其各组成部分的功能;②掌握Maven的使用,包括项目创建、依赖管理、生命周期等;③熟悉HTTP协议的请求响应机制,能够处理常见的HTTP请求和响应;④掌握前端开发技术,如HTML、CSS、JavaScript等,能够进行简单的前端页面开发;⑤了解Tomcat服务器的工作原理及其配置方法。 阅读建议:本文内容丰富,涵盖了从后端到前端的多个方面,建议读者在学习过程中结合实际项目进行实践,尤其是在Maven项目管理和SSM框架的具体应用上,多动手操作,加深理解。同时,对于HTTP协议和前端开发技术,可以通过实际的网络请求和页面开发来巩固所学知识。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值