UVA - 12263 Rankings 模拟(拓扑排序)
题意:1~n这n个数,给你一个初始的顺序,再告诉你那两个数的大小关系发生了变化,求变化后的 顺序,不存在则输出IMPOSSIBLE
思路:这题很遗憾没在比赛的时候过掉,结束后加了一行就AC了。题目真的不难,我就是根据原顺序和变化得到任意两个数之间的大小关系。然后枚举变化后的这些数对,用构造法构造一个合法的序列,最后再和原顺序进行不重复的合并。两个数组,两个指针,合并的时候未发生变化的当前数若大于变化的当前数,则输出原数,否则输出变化后的数,并将对应数组指针后移。再对得到的新顺序进行合法判断,若大小关系和要求的完全一致,则输出答案,否则无解。
这题还有更简单的拓扑排序做法,我正在研究,稍后更新。
#pragma comment(linker, "/STACK:1000000000")
#include <bits/stdc++.h>
#define LL long long
#define INF 0x3f3f3f3f
#define IN freopen("E.in","r",stdin);
#define OUT freopen("out.txt", "w", stdout);
using namespace std;
#define MAXN 505
#define MAXM 25005
int s[MAXM], t[MAXM];
int a[MAXN], b[MAXN], pos[MAXN], c[MAXN];
bool dayu[MAXN][MAXN], res[MAXN][MAXN], u[MAXN][MAXN];
bool vis[MAXN];
int main()
{
int T;
scanf("%d", &T);
int cas = ;
while(T--){
cas++;
int n;
scanf("%d", &n);
for(int i = ; i <= n; i++){
scanf("%d", &a[i]);
}
memset(dayu, , sizeof(dayu));
memset(vis, , sizeof(vis));
memset(b, , sizeof(b));
for(int i = ; i <= n; i++){
for(int j = i + ; j <= n; j++){
dayu[a[i]][a[j]] = true;
}
}
int m;
scanf("%d", &m);
memset(u, , sizeof(u));
for(int i = ; i <= m; i++){
scanf("%d%d", &s[i], &t[i]);
if(u[s[i]][t[i]]) continue;
u[s[i]][t[i]] = true;
dayu[s[i]][t[i]] = !dayu[s[i]][t[i]];
dayu[t[i]][s[i]] = !dayu[t[i]][s[i]];
}
int x, y;
int p = ;
bool noans = false;
for(int i = ; i <= m; i++){
if(dayu[s[i]][t[i]]){
x = t[i];
y = s[i];
}else{
x = s[i];
y = t[i];
}
if(!vis[x]){
vis[x] = true;
int j = p;
if(p == ){
b[++p] = x;
}
else{
while(j >= && dayu[x][b[j]]){
j--;
}
for(int k = p; k > j; k--){
pos[b[k]]++;
b[k + ] = b[k];
}
b[j + ] = x;
p++;
}
pos[x] = j + ;
}
if(!vis[y]){
vis[y] = true;
int j = pos[x] - ;
while(j >= && dayu[y][b[j]]){
j--;
}
for(int k = p; k > j; k--){
pos[b[k]]++;
b[k + ] = b[k];
}
p++;
b[j + ] = y;
pos[y] = j + ;
}
}
int j = ;
memset(pos, , sizeof(pos));
for(int i = ; i <= n; i++){
if(vis[a[i]]){
c[i] = b[j++];
}
else{
if(dayu[a[i]][b[j]] || j > p){
c[i] = a[i];
}
else{
c[i] = b[j++];
}
}
pos[c[i]] = i;
}
memset(res, , sizeof(res));
for(int i = ; i <= n; i++){
for(int j = i + ; j <= n; j++){
res[c[i]][c[j]] = true;
}
}
for(int i = ; i <= n; i++){
for(int j = ; j <= n; j++){
if(res[i][j] != dayu[i][j]){
noans = true;
break;
}
}
if(noans){
break;
}
}
if(noans){
printf("IMPOSSIBLE\n");
continue;
}
for(int i = ; i < n; i++){
printf("%d ", c[i]);
}
printf("%d\n", c[n]);
}
return ;
}
UVA - 12263 Rankings 模拟(拓扑排序)的更多相关文章
- UVA 12263 Rankings(拓扑排序)
给出一个n个数的序列1,然后有m个改动(a, b),在序列2中a跟b在序列中的相对顺序改变.求符合题意的序列2. 题中说道如果一个数的位置不确定,则输出‘?' ,仔细想想,这种情况是不会存在的,因为在 ...
- UVA215-Spreadsheet Calculator(模拟+拓扑排序)
Problem UVA215-Spreadsheet Calculator Accept:401 Submit:2013 Time Limit: 3000 mSec Problem Descript ...
- UVA.10305 Ordering Tasks (拓扑排序)
UVA.10305 Ordering Tasks 题意分析 详解请移步 算法学习 拓扑排序(TopSort) 拓扑排序的裸题 基本方法是,indegree表示入度表,vector存后继节点.在tops ...
- UVA 1572 Self-Assembly(拓扑排序)
1 // 把一个图的所有结点排序,使得每一条有向边(u,v)对应的u都排在v的前面. 2 // 在图论中,这个问题称为拓扑排序.(toposort) 3 // 不难发现:如果图中存在有向环,则不存在拓 ...
- Uva 10305 - Ordering Tasks 拓扑排序基础水题 队列和dfs实现
今天刚学的拓扑排序,大概搞懂后发现这题是赤裸裸的水题. 于是按自己想法敲了一遍,用queue做的,也就是Kahn算法,复杂度o(V+E),调完交上去,WA了... 于是检查了一遍又交了一发,还是WA. ...
- UVa 1572 Self-Assembly (拓扑排序)
题目链接: https://cn.vjudge.net/problem/UVA-1572 Automatic Chemical Manufacturing is experimenting with ...
- UVa 10305 - Ordering Tasks (拓扑排序裸题)
John has n tasks to do. Unfortunately, the tasks are not independent and the execution of one task i ...
- POJ——1308Is It A Tree?(模拟拓扑排序判断有向图是否为树)
Is It A Tree? Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 28399 Accepted: 9684 De ...
- UVA 10305 Ordering Tasks(拓扑排序的队列解法)
题目链接: https://vjudge.net/problem/UVA-10305#author=goodlife2017 题目描述 John有n个任务,但是有些任务需要在做完另外一些任务后才能做. ...
随机推荐
- django 用户上传文件media的存储访问配置1
1. 首先新建文件夹media 后 在项目setting中具体配置: MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media ...
- gRPC全局异常捕获
gRPC全局异常捕获 引 一般的.net项目比如ASP.NET.控制台程序.Windows服务.桌面程序等都会有framework自带的全局异常捕获机制.ASP.NET的ExceptionFilter ...
- 2015 Multi-University Training Contest 4 hdu 5335 Walk Out
Walk Out Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...
- 在Windows上面安装多个Memcached
在Windows上面安装多个Memcached sc create "memcached Server3" start= auto binPath= "D:\memcac ...
- Android五天乐(第三天)ListFragment与ViewPager
1ListFragment 今天首先学习了一种很经常使用的展示场景:列表展示. 昨天学习了使用Fragmet来取代activity进行设计.今天在托管单个fragment的基础上,掌握托管一个布局li ...
- MooseFS源代码分析(二)
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...
- Node.js 博客实例(十)pv统计和留言统计
原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第十章,因为版本号等的原因,在原教程基础上稍加修改就可以实现. post.js中将var post={ ...
- 反弹木马——本质上就是一个开80端口的CS程序,伪造自己在浏览网页
反弹端口型木马分析了防火墙的特性后发现:防火墙对于连入的链接往往会进行非常严格的过滤,但是对于连出的链接却疏于防范.于是,与一般的木马相反,反弹端口型木马的服务端(被控制端)使用主动端口,客户端(控制 ...
- Laravel-路由组和中间件
Laravel-路由组和中间件 标签(空格分隔): php 定义路由组 Route::group(['prefix'=>'Anime'], function(){ Rout::match(['g ...
- zookeeper图形界面工具zooinspector
链接: https://pan.baidu.com/s/1rabrwuC 密码: trwa zooinspector下载地址 解压后进入