高斯消元(行列式)

2017-02-23  本文已影响0人  fo0Old

浮点高斯消元:

int gsxy(int n,int m)
{
    int i=1;
    for(int j=1;i<=n && j<=m;j++)
    {
        int x=i;
        for(int k=i+1;k<=n;k++)
            if(!zero(a[k][j]) && fabs(a[k][j])>fabs(a[x][j]))
               x=k;
        if(zero(a[x][j]))continue;
        for(int k=j;k<=m;k++)
            swap(a[i][k],a[x][k]);
        for(int k=1;k<=n;k++)
        {
            if(k==i || zero(a[k][j]))continue;
            double f=a[k][j]/a[i][j];
            for(int l=j;l<=m;l++)
                a[k][l]-=a[i][l]*f;
        }
        for(int k=m;k>=j;k--)
            a[i][k]/=a[i][j];
        i++;
    }
    return i-1;
}

模意义下高斯消元

int gsxy(int n,int m)
{
    int i=1;
    for(int j=1;i<=n && j<=m;++j)
    {
        int x=i;
        for(int k=i+1;k<=n;++k)
            if(a[k][j] && abs(a[k][j])>abs(a[x][j]))
               x=k;
        if(!a[x][j])continue;
        for(int k=j;k<=m;++k)
            swap(a[i][k],a[x][k]);
        for(int k=1;k<=n;++k)
        {
            if(k==i || !a[k][j])continue;
            ll f=a[k][j]*qpow(a[i][j],mod-2)%mod;
            for(int l=j;l<=m;++l)
            {
                a[k][l]-=a[i][l]*f%mod;
                if(a[k][l]<=-mod)a[k][l]%=mod;
                if(a[k][l]<0)a[k][l]+=mod;
            }
        }
        for(int k=m;k>=j;--k)
            (a[i][k]*=qpow(a[i][j],mod-2))%=mod;
        ++i;
    }
    return i-1;
}

整数行列式求值:

ll a[205][205],mod;

ll det(int n)
{
    ll ans=1,f=1;
    for(int i=1; i<=n; i++)
    {
        for(int j=i+1; j<=n; j++)
        {
            int x=i,y=j;
            while(a[y][i])
            {
                ll t=a[x][i]/a[y][i];
                for(int k=i; k<=n; k++)
                    a[x][k]=(a[x][k]-a[y][k]*t%mod)%mod;
                swap(x,y);
            }
            if(x!=i)
            {
                for(int k=1; k<=n; k++)
                    swap(a[i][k],a[j][k]);
                f=-f;
            }
        }
        ans=ans*a[i][i]%mod;
    }
    return (ans*f+mod)%mod;
}

异或消元:

int xorxy(int n,int m)
{
    int i=1;
    for(int j=1; i<=n && j<=m; j++)
    {
        int x=0;
        for(int k=i; k<=n; k++)
            if(b[k][j])
            {
                x=k;
                break;
            }
        if(!x)continue;
        for(int k=j;k<=m;k++)
            swap(b[i][k],b[x][k]);
        for(int k=1;k<=n;k++)
        {
            if(k==i || !b[k][j])continue;
            for(int l=j;l<=m;l++)
                b[k][l]^=b[i][l];
        }
        i++;
    }
    return i-1;
}
上一篇 下一篇

猜你喜欢

热点阅读