线性基求交

设有两个线性基 \(\alpha,\beta\),如果 \(\beta_i\) 能被 \(\theta \bigcup \phi, \theta \subseteq \alpha,\phi \subseteq \{\beta_0,\beta_1,...,\beta_{i-1}\}\) 表示,则把 \(\theta\) 加入答案线性基即可

#include 
using namespace std;

#define int long long

struct linearbase
{
    int a[64];
    linearbase()
    {
        memset(a,0,sizeof a);
    }
    void insert(int k)
    {
        for(int j=60; j>=0; --j)
            if((k>>j)&1ll)
                if(a[j]==0)
                {
                    a[j]=k;
                    break;
                }
                else k^=a[j];
    }
    int& operator [] (int i)
    {
        if(i<64) return a[i];
    }
    bool check(int x)
    {
        for(int i=60; i>=0; --i)
        {
            if((a[i]^x)=0;--i) if(a[i]) cout<=0;--i)
        {
            all[i]=a[i];
            d[i]=1ll<=0;--i)
        {
            if(b[i])
            {
                int v=b[i],k=0,fg=1;
                for(int j=60;j>=0&&fg;j--)
                {
                    if(v>>j&1)
                    {
                        if(all[j]) v^=all[j],k^=d[j];
                        else all[j]=v,d[j]=k,fg=0;
                    }
                }
                if(fg)
                {
                    int v=0;
                    for(int j=60;j>=0;j--)
                    {
                        if(k>>j&1) v^=a[j];
                    }
                    c.insert(v);
                }
            }
        }
        return c;
    }
    int solve() {
        int ans = 0;
        for(int i=60; i>=0; --i)
            if((ans^a[i]) > ans) ans^=a[i];
        return ans;
    }
};

signed main()
{
    linearbase a,b;
    a.insert(1);
    a.insert(2);
    b.insert(3);
    linearbase c=a*b;
    a.print();
    b.print();
    c.print();
}

你可能感兴趣的:(线性基求交)