【链接】h在这里写链接


【题意】


有N个人。
2N个座位。
现在告诉你这N个人它们现在的座位。以及它们想去的座位。
每个人可以去它们想去的座位或者就站在原地不动。
新的座位和旧的座位,都不允许一个座位被两个人占据的情况。
问你安排的方案数。

【题解】


这是一个n个节点,n条边的图。
构成的图有两种情况。
->各个连通块独立计算答案,然后乘起来。
如果n个点,n-1条边。
则是一棵树。
那么写个例子就会发现,答案就是节点的个数。

如果n个点,那条边

会出现一个环(且恰好只有一个环);

如果是一个自环。那么答案为1.

因为所有人都不能动。->动了的话,那个自环上的人是无法走的。

如果这个环的长度大于等于2.

则答案为2.

因为除了环上的人,其他人都不能动。

且环上的人要么全动,要么全不动。

两种情况。

可以用并查集来判断有没有出现环。

如果是自环的话,答案直接设置为1就好。

如果没有环。

则答案为并查集的大小(找f(i)==i的根节点);

如果有环

答案就为2.

(各个连通块答案累乘就好)



【错的次数】


2

【反思】


tarjan不知道哪里写错了>_<
下次一个环的这种题就别写tarjan了。
并查集找环很方便啊!

【代码】

#include <bits/stdc++.h>
using namespace std; const int N = 2e5;
const long long MOD = 1e9+7; int n,f[N+10],cycle[N+10],size[N+10]; int ff(int x){ if (f[x]==x) return x;else return f[x] = ff(f[x]);} int main(){
//freopen("F:\\rush.txt","r",stdin);
ios::sync_with_stdio(0),cin.tie(0);
cin >> n;
for (int i = 1;i <= 2*n;i++) f[i] = i,size[i]=1;
for (int i = 1,x,y;i <= n;i++){
cin >> x >> y;
if (x==y){
cycle[ff(x)]=2;
continue;
}
int r1 = ff(x),r2 = ff(y);
if (r1!=r2){
f[r2] = r1;
size[r1]+=size[r2];
cycle[r1]|=cycle[r2];
}else
cycle[r1] = 1;
}
long long ans = 1;
for (int i = 1;i <= 2*n;i++)
if (ff(i)==i){
if (cycle[i]==1)
ans = ans*2%MOD;
else
if (cycle[i]==0)
ans = ans*size[i]%MOD;
}
cout << ans << endl;
return 0;
}

【MemSQL Start[c]UP 3.0 - Round 1 E】Desk Disorder的更多相关文章

  1. 【MemSQL Start[c]UP 3.0 - Round 1 C】 Pie Rules

    [链接]h在这里写链接 [题意] 在这里写题意 [题解]     dp[i][0] 第i个位置,bob没有决策权     dp[i][1] 第i个位置,bob有决策权     dp[n][0] = 0 ...

  2. 【MemSQL Start[c]UP 3.0 - Round 1 B】 Lazy Security Guard

    [链接]h在这里写链接 [题意] 围成对应面积的方块最少需要多少条边. [题解] 有特定的公式的. 2*ceil(2*根号下(n)); -> 自己找下规律也很简单的. [错的次数] 0 [反思] ...

  3. 【MemSQL Start[c]UP 3.0 - Round 1 A】 Declined Finalists

    [链接]h在这里写链接 [题意] 在这里写题意 [题解] max(最大值-25,0) [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc++.h> ...

  4. 【Xamarin挖墙脚系列:Xamarin4.0的重大变更】

    原文:[Xamarin挖墙脚系列:Xamarin4.0的重大变更] Windows下的变更不大,主要还是bug 的修复,性能的优化,API的扩展实现. 变化最大的是在Mac上的那个Xamarin.iO ...

  5. [No00006D]下载离线版的github for windows【以Github for Windows 3.0.110.为例】

    目录 先上地址后讲原理: 原理: 11个目录的文件怎么一口气下载呢? 最后,把下好的文件批量名,同时将GitHub.exe.manifest也放到软件根目录下(与GitHub.exe同级): 今后的猜 ...

  6. MemSQL Start[c]UP 2.0 - Round 1(无聊练手B题)

    http://codeforces.com/contest/452/problem/B   B. 4-point polyline time limit per test 2 seconds memo ...

  7. MemSQL Start[c]UP 2.0 - Round 2 - Online Round

    搞到凌晨4点一个没出,要gg了. A. Golden System http://codeforces.com/contest/458/problem/A #include<cstdio> ...

  8. MemSQL Start[c]UP 2.0 - Round 1

    A. Eevee http://codeforces.com/contest/452/problem/A 字符串水题 #include<cstdio> #include<cstrin ...

  9. MemSQL Start[c]UP 2.0 - Round 2

    反正晚上睡不着,熬到1点开始做比赛,6个题目只做了2个题目,而且手速还比较慢,待提升空间还很大呢. A题:给定两个0,1串(len<=100000), 但是不是普通的二进制串,而是q进制串,q ...

随机推荐

  1. ADB高级应用

    ADB高级应用 一.利用无线来查看adb shell > adb tcpip 5555 连接: > adb connect IP:5555 见后文<调试注意事项> 二.模拟按键 ...

  2. 值得学习的html知识

    这里零度为大家推荐几个值得学习的html知识,很有用的哦! 一.打开窗口即最大化 <script language="javaScript"> <!-- Begi ...

  3. Cloudera Hue是什么?

     Hue是cdh专门的一套web管理器,它包括3个部分hue ui,hue server,hue db.hue提供所有的cdh组件的shell界面的接口.你可以在hue编写mr,查看修改hdfs的文件 ...

  4. Linux下截图技巧

           在需要Linux显示图片的场合,最普通的方法,会考虑用数码相,或是用Vmware,或VPc来抓拍,这样以来会比较麻烦,Linux也自带了些工具例如Gimp,ksnapshot这里我介绍一 ...

  5. kali之Nmap (Network Mapper(网络映射器)

    Nmap是主机扫描工具,他的图形化界面是Zenmap,分布式框架为Dnamp. Nmap可以完成以下任务: 主机探测 端口扫描 版本检测 系统检测 支持探测脚本的编写 Nmap在实际中应用场合如下: ...

  6. groupdel---删除指定的工作组

    groupdel命令 groupdel命令用于删除指定的工作组,本命令要修改的系统文件包括/ect/group和/ect/gshadow.若该群组中仍包括某些用户,则必须先删除这些用户后,方能删除群组 ...

  7. 通过Gradle来下载依赖的jar包

    前段时间在看Gradle文章方向其比ANT.Maven真的要简单很多,特别是在下载jar依赖方面下面就是用gradle写的一个jar包依赖下载的小例子: (1)建立build.gradle文件 (2) ...

  8. 【iOS与EV3混合机器人编程系列之中的一个】iOS要干嘛?EV3能够更酷!

    乐高Mindstorm EV3智能机器人(下面简称EV3)自从在2013年的CES(Consumer Electronics Show美国消费电子展)上展出之后,就吸引了全球广大机器人爱好者的眼球!E ...

  9. worktools-不同分辨率下图片移植

    1.下载需要移植的平台代码 1)查看手机需要的项目平台信息:adb shell getprop | gerp flavor     ----->mt6732_m561_p2_kangjia_cc ...

  10. 9.Maven之(九)依赖关系

    转自:https://yq.aliyun.com/ziliao/312160 在maven的管理体系中,各个项目组成了一个复杂的关系网,但是每个项目都是平等的,是个没有贵贱高低,众生平等的世界,全球每 ...