B. pSort
2024-08-31 20:57:09
题目链接:
http://codeforces.com/problemset/problem/28/B
题意:
给一个n,原本有个1到n按顺序排列的序列,给一个序列问,在给一个数组,表示这个位置的数可以换到pi位置,问能不能实现给的那个序列的排列。如果可以输出yes相反输出no
思路:
通过画图可知同一个集合的数字一定可以相互交换位置。所以这里使用并查集就好。
代码:
#include<bits/stdc++.h>
#define LL long long using namespace std;
const int maxn=+;
struct node
{
int to,Next;
};
int Head[maxn];
node Edge[maxn*];
int cnt=;
int a[maxn],b[maxn],Fa[maxn];
void add(int u,int v)
{
Edge[++cnt].to=v;
Edge[cnt].Next=Head[u];
Head[u]=cnt;
return ;
}
int Find(int x)
{
if(x==Fa[x])
{
return x;
}
else
{
return Fa[x]=Find(Fa[x]);
}
}
int main()
{
int n;
cin>>n;
for(int i=;i<=n;i++)
{
Fa[i]=i;
}
for(int i=;i<=n;i++)
{
cin>>a[i];
}
for(int i=;i<=n;i++)
{
cin>>b[i];
}
for(int i=;i<=n;i++)
{
if(i+b[i]<=n||i-b[i]>=)
{
int root1=Find(i);
if(i+b[i]<=n)
{
int root2=Find(i+b[i]);
if(root1!=root2)
{
Fa[root2]=root1;
}
}
if(i-b[i]>=)
{
int root2=Find(i-b[i]);
if(root1!=root2)
{
Fa[root2]=root1;
}
}
}
}
int flag=;
for(int i=;i<=n;i++)
{
int root1=Find(a[i]);
int root2=Find(i);
if(root1!=root2)
{
//cout<<i<<" "<<a[i]<<endl;
flag=;
break;
}
}
if(flag)
{
cout<<"YES"<<endl;
}
else
{
cout<<"NO"<<endl;
}
return ;
}
最新文章
- Squirrel: 通用SQL、NoSQL客户端
- IntelliJ IDEA的快捷键
- HDU 4940 Destroy Transportation system(2014 Multi-University Training Contest 7)
- WCF入门 (14)
- python 调用 C++ code
- Eclipse使用技巧总结
- SSH与EJB 比较
- Oracle- 存储过程和异常捕捉
- LoadRunner测试问题
- Terminating app due to uncaught exception &#39;NSUnknownKeyException&#39;, reason: xxxx
- 关于链接target的问题
- c/c++数组名和指针区别深入探索
- USACO Section 1.2 Name That Number 解题报告
- CCNA笔记(3)
- Win下安装nvm
- 《Gogoing》Alpha版会议总结
- GCC内置函数
- Python实现向s3共享存储上传和下载文件
- 性能调优之MySQL篇二:MySQL配置文件My.ini配置文件优化
- Recsys2018 music recomendation