【bzoj2844】albus就是要第一个出场
Time Limit: 6 Sec Memory Limit: 128 MB
Submit: 2254 Solved: 934
[Submit][Status][Discuss]
Description
Input
第一行一个数n, 为序列A的长度。接下来一行n个数, 为序列A, 用空格隔开。最后一个数Q, 为给定的数.
Output
Sample Input
1 2 3
1
Sample Output
样例解释:
N = 3, A = [1 2 3]
S = {1, 2, 3}
2^S = {空, {1}, {2}, {3}, {1, 2}, {1, 3}, {2, 3}, {1, 2, 3}}
f(空) = 0
f({1}) = 1
f({2}) = 2
f({3}) = 3
f({1, 2}) = 1 xor 2 = 3
f({1, 3}) = 1 xor 3 = 2
f({2, 3}) = 2 xor 3 = 1
f({1, 2, 3}) = 0
所以
B = [0, 0, 1, 1, 2, 2, 3, 3]
HINT
数据范围:
1 <= N <= 10,0000
其他所有输入均不超过10^9
Source
题解:
问题即求子集异或和的某个数的排名;
线性基的性质:若$A,|A|=n$的线性基为$B$,$|B|=k$,则有$2^k$个不同的子集异或和,且每个会出现$2^{n-k}$次;
- 由基的线性无关性可以知道有且仅有$^k$个异或和互不相同;
- 这k个基是可以从$a_i$里选出来的,只是我们为了好写,一般插入就直接消元到某个数组里;
- 考虑他们的子集异或和S1,另外有$n-k$个数,可以被B中的向量唯一表示,考虑子集异或和S2 ;
- S1 ^ S2 也是一种合法的选法;
- 这样有$^k * ^{n-k} = ^n$种 ,说明只有$^n$且按照这种方式对应;
如果你关心一个蒟蒻的不太严谨的证明的话
高斯亚当消元求出互相独立的线性基,在线性基上一个一个查找;
注意消元的两个循环(line23 line24 )有顺序;
复杂度;$ O(n log \ a_{i} + log \ a_{i}) $
20181030
- #include<cstdio>
- #include<iostream>
- #include<algorithm>
- #include<cstring>
- #include<queue>
- #include<cmath>
- #include<vector>
- #include<stack>
- #include<map>
- #include<set>
- #define Run(i,l,r) for(int i=l;i<=r;i++)
- #define Don(i,l,r) for(int i=l;i>=r;i--)
- #define ll long long
- #define inf 0x3f3f3f3f
- using namespace std;
- const int N= , mod=;
- int n,d[],q;
- void ins(int x){
- for(int i=;~i;i--)if((x>>i)&){
- if(!d[i]){
- d[i]=x;
- for(int j=;j<i;j++)if(d[j]&&((d[i]>>j)&))d[i]^=d[j];
- for(int j=;j>i;j--)if((d[j]>>i)&)d[j]^=d[i];
- break;
- }
- else x^=d[i];
- }
- }
- int pw(int x,int y){
- int re=;
- while(y){
- if(y&)re=re*x%mod;
- y>>=;x=x*x%mod;
- }
- return re;
- }
- int query(int x){
- int re=,cnt=;
- for(int i=;~i;i--)if(d[i])cnt++;
- int tmp=cnt;
- for(int i=;~i;i--)if(d[i]){
- tmp--;
- if((x^d[i])<x){
- x^=d[i];
- re=(re+pw(,tmp))%mod;
- }
- }
- re=re*pw(,n-cnt)%mod;
- return re;
- }
- int main(){
- freopen("in.in","r",stdin);
- freopen("out.out","w",stdout);
- scanf("%d",&n);
- Run(i,,n){
- int x;scanf("%d",&x);
- ins(x);
- }
- int x;scanf("%d",&x);
- cout<<(query(x)+)%mod<<endl;
- return ;
- }//by tkys_Austin;
【bzoj2844】albus就是要第一个出场的更多相关文章
- BZOJ2844: albus就是要第一个出场
Description 已知一个长度为n的正整数序列A(下标从1开始), 令 S = { x | 1 <= x <= n }, S 的幂集2^S定义为S 所有子集构成的集合. 定义映射 f ...
- BZOJ2844: albus就是要第一个出场(线性基)
Time Limit: 6 Sec Memory Limit: 128 MBSubmit: 2054 Solved: 850[Submit][Status][Discuss] Descriptio ...
- bzoj千题计划195:bzoj2844: albus就是要第一个出场
http://www.lydsy.com/JudgeOnline/problem.php?id=2844 题意:给定 n个数,把它的所有子集(可以为空)的异或值从小到大排序得到序列 B,请问 Q 在 ...
- 【贪心】【线性基】bzoj2844 albus就是要第一个出场
引用题解:http://blog.csdn.net/PoPoQQQ/article/details/39829237 注意评论区. #include<cstdio> using names ...
- 【线性基】bzoj2844: albus就是要第一个出场
线性基求可重rank 题目描述 给定 n 个数 $\{ a_i \}$ ,以及数 $x$. 将 $\{ a_i \}$ 的所有子集(包括空集)的异或值从小到大排序,得到 $\{ b_i \} $. ...
- CF895C: Square Subsets && 【BZOJ2844】albus就是要第一个出场
CF895C: Square Subsets && [BZOJ2844]albus就是要第一个出场 这两道题很类似,都是线性基的计数问题,解题的核心思想也一样. CF895C Squa ...
- 【BZOJ2844】albus就是要第一个出场 高斯消元求线性基
[BZOJ2844]albus就是要第一个出场 Description 已知一个长度为n的正整数序列A(下标从1开始), 令 S = { x | 1 <= x <= n }, S 的幂集2 ...
- BZOJ 2844: albus就是要第一个出场 [高斯消元XOR 线性基]
2844: albus就是要第一个出场 题意:给定一个n个数的集合S和一个数x,求x在S的$2^n$个子集从小到大的异或和序列中最早出现的位置 一开始看错题了...人家要求的是x第一次出现位置不是第x ...
- BZOJ 2844: albus就是要第一个出场
2844: albus就是要第一个出场 Time Limit: 6 Sec Memory Limit: 128 MBSubmit: 1134 Solved: 481[Submit][Status] ...
- 2844: albus就是要第一个出场
2844: albus就是要第一个出场 链接 分析: 和HDU3949差不多互逆,这里需要加上相同的数. 结论:所有数任意异或,构成的数出现一样的次数,次数为$2^{n-cnt}$,cnt为线性基的大 ...
随机推荐
- ubuntu apt-xxx
1. apt-get install xxx 2. dpkg -l ; list software already installed. 3. apt-cache dumpavail ; print ...
- HTML从入门到放弃
一.HTML 简介 链接:https://www.cnblogs.com/baishuchao/articles/9179920.html 二.HTML 基础 链接:https://www.cnblo ...
- Siki_Unity_2-3_UGUI_Unity4.6 UI Beta版本入门学习(未学)
Unity 2-3 UGUI Unity4.6 UI Beta版本入门学习(未学)
- Python教程 深入条件控制
while 和 if 条件句中可以使用任意操作,而不仅仅是比较操作. 比较操作符 in 和 not in 校验一个值是否在(或不在)一个序列里.操作符 is 和 is not 比较两个对象是不是同一个 ...
- loadrunner socket协议问题归纳(1)
前段时间测了loadrunner直接发送报文到socket上的性能测试.在此,稍微回顾整理下. 与socket通讯,有两种方式,一种是建立长连接,建立后,不停的发送,接收.另外一种是建立短连接,建立连 ...
- node.js常用方法
1.获取真实地址 function getClientIp(req) { return req.headers['x-forwarded-for'] || req.connection.remoteA ...
- 网站UI分析
本次网站UI分析我选择的是我们石家庄铁道大学的网站,首先对于网站的分析建立在我经常使用鼠须的基础上,我可以很好的站在用户的角度来进行分析,否则对于你不熟悉的网站你可能是不能很好地体验到他的 结构. U ...
- 运维学习笔记(七)之T02-01计算机网络 、 数制 、 网络通信参考模型
计算机网络 计算机网络概述 什么是计算机网络 硬件方面:通过线缆将网络设备和计算机连接起来 软件方面:操作系统.应用软件.应用程序通过通信线路互连 实现资源共享.信息传递 功能 数据通信/资源共享/增 ...
- <问吧>调查问卷心得体会
<问吧>调查问卷心得与体会 在这之前,我们已经组成了一个六个人的小团队---“走廊奔跑队”,我们这次做的这个项目的名称是:问吧.在项目实施之前,我们必做的一步就是需求分析,目的就是充分了解 ...
- QHash和QMultiHash使用
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QHash和QMultiHash使用 本文地址:http://techieliang. ...