2024ICPC网络赛第一场C. Permutation Counting 4(线性代数)

题目链接

题目大意:给你n个范围 l i , r i l_i,r_i li,ri,每个位置可以在这个范围中选择一个数,然后形成排列1到n的排列p。问p的所有情况的个数的奇偶性。

一个很妙的行列式转化,纯纯的线性代数。

首先,我们把p的总数表示出来。设矩阵 a i , j a_{i,j} ai,j,表示的是第 i 个 i个 i个位置的是否可以表示 j j j。则p的所有可能为 ∑ p Π i = 1 n a i , P i \sum\limits_{p}\mathop{\Pi}\limits_{i=1}^{n}a_{i,Pi} p∑i=1Πnai,Pi

其中p表示所有排列方式的总和。发现这是近似于矩阵a的行列式的值,不过去掉了其正负号。(在取模2的影响下,综合的加减没有影响)也就是说,只要我们求矩阵 a a a的行列式的值 m o d 2 mod\ 2 mod 2,就可以解出最终解。

根据矩阵的性质,矩阵的行列式 m o d 2 mod\ 2 mod 2为 0 0 0,等价于该矩阵 m o d 2 mod\ 2 mod 2下不可逆,也等价于该矩阵 m o d 2 mod\ 2 mod 2下的每一行的向量存在线性相关,也就是存在其中一个向量可以被其它向量表示。

至此,我们终于该题从看不懂的样子转化成了看起来像人话的子问题了。让我们解决这个子问题。每一个位置的向量 l i , r i l_i,r_i li,ri我们可以通过 r i − ( l i − 1 ) r_i-(l_{i}-1) ri−(li−1)表示,然后通过并查集判断出该向量能否通过其它向量表示。

cpp 复制代码
int n,m;

int pre[1000005];

int find (int x){
    if(pre[x]==x)return x;
    else return pre[x]=find(pre[x]);
}

void icealsoheat(){
    
    cin>>n;

    for(int i=0;i<=n;i++)pre[i]=i;

    int ans=1;

    for(int i=1;i<=n;i++){
        int l,r;
        cin>>l>>r;
        l=find(l-1);
        r=find(r);

        if(l==r){
            ans=0;
            // break;
        }
        else{
            pre[l]=r;
        }
    }

    cout<<ans<<"\n";

}
相关推荐
如竟没有火炬几秒前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
SilentSamsara3 分钟前
scikit-learn 工作流工程化:Pipeline、ColumnTransformer 与自定义转换器
开发语言·人工智能·python·机器学习·青少年编程·numpy·scikit-learn
我命由我123454 分钟前
Kotlin 开发 - Kotlin 反引号转义关键字
android·java·开发语言·java-ee·kotlin·android jetpack·android runtime
大白话_NOI7 分钟前
【洛谷 P1480】A/B Problem(高精度除法 Ⅰ)详细题解
c++
j7~7 分钟前
【C++】C&C++内存管理--之内存分布,operatenew/new,operate/delete的底层原理.
c语言·c++·delete·内存泄漏·new·operate new·动态内存分布
Hillain8 分钟前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
拂拉氏11 分钟前
【项目分享-知识讲解】 C++标准库 list类的模拟实现
开发语言·c++·list·封装·stl标准库
十月的皮皮11 分钟前
C语言学习笔记20260603-打印整数(32位)二进制的奇数位和偶数位(2种方法)
c语言·笔记·学习
码云骑士11 分钟前
【2.Java基础】Java常量与变量-从基本类型到类型转换全面掌握
java·开发语言
爱和冰阔落13 分钟前
Ollama 本地大模型部署实战:从安装到 RAG 知识库完整指南
开发语言·大模型·php·ollama