BZOJ:2460[BeiJing2011]元素 (异或基+贪心)
2460: [BeiJing2011]元素
Time Limit: 20 Sec  Memory Limit: 128 MB
Submit: 2910  Solved: 1535
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2460
Description:
相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术。那时人们就认识到,一个法杖的法力取决于使用的矿石。一般地,矿石越多则法力越强,但物极必反:有时,人们为了获取更强的法力而使用了很多矿石,却在炼制过程中发现魔法矿石全部消失了,从而无法炼制出法杖,这个现象被称为“魔法抵消” 。特别地,如果在炼制过程中使用超过一块同一种矿石,那么一定会发生“魔法抵消”。
后来,随着人们认知水平的提高,这个现象得到了很好的解释。经过了大量的实验后,著名法师 Dmitri 发现:如果给现在发现的每一种矿石进行合理的编号(编号为正整数,称为该矿石的元素序号),那么,一个矿石组合会产生“魔法抵消”当且仅当存在一个非空子集,那些矿石的元素序号按位异或起来为零。 (如果你不清楚什么是异或,请参见下一页的名词解释。 )例如,使用两个同样的矿石必将发生“魔法抵消”,因为这两种矿石的元素序号相同,异或起来为零。 并且人们有了测定魔力的有效途径,已经知道了:合成出来的法杖的魔力等于每一种矿石的法力之和。人们已经测定了现今发现的所有矿石的法力值,并且通过实验推算出每一种矿石的元素序号。
现在,给定你以上的矿石信息,请你来计算一下当时可以炼制出的法杖最多有多大的魔力。
Input:
第一行包含一个正整数N,表示矿石的种类数。 接下来 N行,每行两个正整数Numberi 和 Magici,表示这种矿石的元素序号和魔力值。
Output:
仅包一行,一个整数:最大的魔力值。
Sample Input:
3 
  1 10 
  2 20 
  3 30
Sample Output:
50
题解:
考虑贪心,将权值大的排在前面,然后扫一遍,将编号插入线性基中,如果当前编号插入不进去,那么就不要这个权值,可以证明这样的贪心选择是最优的。因为如果你要了,你就会损失更大的权值,但是你最终得到的异或值是相同的。
代码如下:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = ;
int n;
struct node{
ll id;
ll v;
bool operator < (const node &A)const{
return v>A.v;
}
}a[N];
ll ans;
ll p[];
void xor_base(){
ans=;
for(int i=;i<=n;i++){
int flag=;
for(ll j=;j>=;j--){
if((1LL<<j)&a[i].id){
if(!p[j]){
p[j]=a[i].id;
flag=;
break;
}
a[i].id^=p[j];
}
}
if(flag) ans+=a[i].v;
}
}
int main(){
ios::sync_with_stdio(false);cin.tie();
cin>>n;
for(int i=;i<=n;i++){
cin>>a[i].id>>a[i].v;
}
sort(a+,a+n+);
xor_base();
cout<<ans;
return ;
}
BZOJ:2460[BeiJing2011]元素 (异或基+贪心)的更多相关文章
- bzoj 2460: [BeiJing2011]元素【线性基+贪心】
		先按魔力值从大到小排序,然后从大到小插入线性基中,如果插入成功就加上这个魔力值 因为线性基里是没有异或和为0的集合的,所以正确性显然,然后最优性,考虑放进去一个原来没选的,这样为了可行性就要删掉一个, ... 
- BZOJ 2460: [BeiJing2011]元素 线性基
		2460: [BeiJing2011]元素 Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法杖的法力 ... 
- BZOJ 2460: [BeiJing2011]元素
		2460: [BeiJing2011]元素 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 878 Solved: 470[Submit][Statu ... 
- BZOJ.2460.[BeiJing2011]元素(线性基 贪心)
		题目链接 线性基:https://blog.csdn.net/qq_36056315/article/details/79819714. \(Description\) 求一组矿石,满足其下标异或和不 ... 
- BZOJ 2460: [BeiJing2011]元素  贪心,线性基
		题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2460 解法:从大到小排序,依次贪心的添加到当前集合就可以了,需要动态维护线性基.用拟阵证明 ... 
- bzoj 2460  [BeiJing2011]元素 (线性基)
		链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2460 题意: 给你一堆矿石,矿石有a,b两种性质,取任意个矿石,满足取得的这些矿石a性质异或 ... 
- BZOJ 2460 [BeiJing2011]元素 ——线性基
		[题目分析] 线性基,由于最多有63个,只需要排序之后,动态的去维护线性基即可. [代码] #include <cstdio> #include <cstring> #incl ... 
- BZOJ 2460  [BeiJing2011]元素(线性基模板题)
		Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法杖的法力取决于使用的矿石.一般地,矿石越多则法力越强 ... 
- BZOJ2460 Beijing2011元素(线性基+贪心)
		按价值从大到小考虑每个元素,维护一个线性基,如果向其中加入该元素的编号仍然构成线性基,则将其加入. 不会证明.当做线性基的一个性质吧. #include<iostream> #includ ... 
随机推荐
- sparkML原始数据转换成label-features方法
			数据1:kaggle-旧金山犯罪分类数据 格式如下: Dates,Category,Descript,DayOfWeek,PdDistrict,Resolution,Address,X,Y -- :: ... 
- adb 常用命令及操作
			获取序列号: adb get-serialno 查看连接计算机的设备: adb devices 重启机器: adb reboot 重启到bootloader,即刷机模式: adb reboot boo ... 
- java length属性、length()、size()
			length属性 length是属性,用于说明数组的长度. String []list={"wo","shi","shuaibi"}; Sy ... 
- [2018 ACL Long] 对话系统
			[NLG - E2E - knowledge guide generation] 1. Knowledge Diffusion for Neural Dialogue Generation ( Ci ... 
- kaldi - Online Audio Server(服务器客户端建立方法-旧版在线解码)
			目录 一.服务器客户端识别系统建立方法 1. Command line to start the server(服务器端启动方式): 2. Command line to start the clie ... 
- 基础数据类型-tuple
			Python中,元组tuple与list类似,不同之处在于tuple的元素不能修改,tuple使用(),list使用[], (1)元组的创建使用(),需要注意的是创建包含一个元素的元组: tuple_ ... 
- HDU 3262/POJ 3829 Seat taking up is tough(模拟+搜索)(2009 Asia Ningbo Regional)
			Description Students often have problems taking up seats. When two students want the same seat, a qu ... 
- a3
			队名 massivehard 组员一(组长:晓辉) 今天完成了哪些任务 .整理昨天的两个功能,补些bug 写了一个初步的loyaut 还剩哪些任务: 后台的用来处理自然语言的服务器还没架. 推荐算法还 ... 
- 《剑指offer》---丑数
			本文算法使用python3实现 1. 问题1 1.1 题目描述: 把只包含因子2.3和5的数称作丑数(Ugly Number).判断一个数是否是丑数. 时间限制:1s:空间限制:32768K ... 
- iOS开发开辟线程总结--NSThread
			1.简介: 1.1 iOS有三种多线程编程的技术,分别是: 1..NSThread 2.Cocoa NSOperation (iOS多线程编程之NSOperation和NSOperationQueue ... 
