【HDU3949】XOR 线性基

博客介绍了如何解决一道名为「HDU3949」的编程题,题目要求计算一系列数的异或和,并找出第k大的异或和。线性基在此问题中起到关键作用,通过将k的二进制形式与线性基进行异或操作来获取答案。博主指出了最初错误的实现方式会导致WA(Wrong Answer),并解释了错误的原因在于不正确的线性基维护策略,可能导致高位1丢失,进而导致计算错误。最终,博主提供了AC(Accepted)代码。
摘要由CSDN通过智能技术生成

#include <stdio.h>
int main()
{
	puts("转载请注明出处谢谢");
	puts("http://blog.csdn.net/vmurder/article/details/43448493");
}


题意:给若干个数让你异或,然后询问第k大的异或和。


题解:

先搞出来线性基,然后第k大的异或和就是:

把k二进制拆分,第i位上有1,就把第i个线性基异或进来。

原因:

因为线性基是一堆高位上的1(或许有一些位动不了),然后把这样每一位可以填0/1,跟二进制差不多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值