【模板】线性基求交

线性基求交

struct lb{
    ll p[63];
    lb(){
        memset(p,0,sizeof(p));
    }
    void clear(){
        memset(p,0,sizeof(p));
    }
    void ins(ll x){
        for(int i=60;i>=0;i--) if((x>>i)&1){
            if(!p[i]){
                p[i]=x;
                return;
            }else x^=p[i];
        }
    }
};
lb merge(lb a,lb b){
    lb g=lb(),tmp=a;
    ll cur,d;
    for(int i=0;i<=60;i++) if(b.p[i]){
        cur=0,d=b.p[i];
        for(int j=i;j>=0;j--) if(d>>j&1){
            if(tmp.p[j]){
                d^=tmp.p[j],cur^=a.p[j];
                if(d) continue;
                g.p[i]=cur;
            }else tmp.p[j]=d,a.p[j]=cur;
            break;
        }
    }
    return g;
}

原文地址:https://www.cnblogs.com/xyq0220/p/11625761.html

时间: 2024-10-01 09:40:54

【模板】线性基求交的相关文章

线性基求交板子

_ operator + (const _ &rhs) const { _ ret; unsigned p[32]{}, f[32]{}; REP(i,0,31) p[i] = a[i]; PER(i,0,31) { auto x = rhs.a[i], y = 1u<<i; PER(j,0,31) if (x>>j&1) { if (p[j]) x^=p[j],y^=f[j]; else { p[j]=x,f[j]=y; break; } } if (x==0)

hdu3949(线性基,求第k小的异或和

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3949 XOR Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4731    Accepted Submission(s): 1658 Problem Description XOR is a kind of bit operator, we

[hdu3949]XOR(线性基求xor第k小)

题目大意:求xor所有值的第k小,线性基模板题. #include<cstdio> #include<cstring> #include<algorithm> #include<cstdlib> #include<iostream> #include<cmath> using namespace std; typedef long long ll; const int MAX_BASE=63; ll base[64],a[10006]

[P3812][模板]线性基

解题关键:求异或最大值.线性基模板题. 极大线性无关组的概念. 异或的值域相同. #include<cstdio> #include<cstring> #include<algorithm> #include<cstdlib> #include<iostream> #include<cmath> using namespace std; typedef long long ll; const int MAX_BASE=63; ll b

[算法模板]线性基

线性基 GavinZheng敲懒的... menci大佬的线性基博客 模板代码引自menci: struct LinearBasis { long long a[MAXL + 1]; LinearBasis() { std::fill(a, a + MAXL + 1, 0); } LinearBasis(long long *x, int n) { build(x, n); } void insert(long long t) { for (int j = MAXL; j >= 0; j--)

[模板]线性基

用途 处理关于子集的异或和的问题,比如子集异或和的最大值,或者能不能异或出某个数 原理 从一堆数中处理出一组线性无关(?)的数,使得这些数能异或出的数和原来能异或出的数相同 线性基中,以每个位置为最高位1的数(最多)只有一个,这样就保证了线性无关 做法 依次处理每个数,对于x,从大到小扫描它的每一位,当扫到第i位为1时: 若线性基中没有最高位为i的数,则把x插到线性基中,结束扫描 若有,则把x异或上那个数,继续做 这样做,如果一个数最终没有被插入线性基中,证明它已经能被线性基中的数表示 而插到线

P3812 【模板】线性基(求最大值)

题目背景 这是一道模板题. 题目描述 给定n个整数(数字可能重复),求在这些数中选取任意个,使得他们的异或和最大. 输入输出格式 输入格式: 第一行一个数n,表示元素个数 接下来一行n个数 输出格式: 仅一行,表示答案. 输入输出样例 输入样例#1: 复制 2 1 1 输出样例#1: 复制 1 说明 1≤n≤50,0≤Si≤250 1 \leq n \leq 50, 0 \leq S_i \leq 2 ^ {50} 1≤n≤50,0≤Si?≤250 CODE: 1 #include <bits/

Yahoo Programming Contest 2019.E.Odd Subrectangles(思路 线性基)

题目链接 \(Description\) 给定一个\(n\times m\)的\(01\)矩阵.求任意选出\(r\)行.\(c\)列(共\(2^{n+m}\)种方案),使得这\(r\)行\(c\)列的交的位置的\(r\times c\)个数的和为奇数,的方案数有多少. (...我也不知道怎么就表述成这样了,反正挺好理解) \(n,m\leq300\). \(Solution\) 假设已经确定了选择某些行,然后把每一行\(m\)个数看做一个\(m\)位二进制数. 如果这些行异或和为\(0\),那怎

BZOJ3759: Hungergame 博弈论+线性基

学了新的忘了旧的,还活着干什么 题意:一些盒子,每步可选择打开盒子和取出已打开盒子的任意多石子,问先手是否必胜 搬运po姐的题解: 先手必胜的状态为:给出的数字集合存在一个异或和为零的非空子集,则先手必胜 证明: 首先我们有状态A:当前的所有打开的箱子中的石子数异或和为零,且所有关闭的箱子中的石子数的集合中不存在一个异或和为零的非空子集 易证A状态时先手必败 先手有两种操作: 1.从一个打开的箱子中拿走一些石子 那么根据Nim的结论 后手可以同样拿走一些石子使状态恢复为A状态 2.打开一些箱子