题意: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 模拟(拓扑排序)的更多相关文章

  1. UVA 12263 Rankings(拓扑排序)

    给出一个n个数的序列1,然后有m个改动(a, b),在序列2中a跟b在序列中的相对顺序改变.求符合题意的序列2. 题中说道如果一个数的位置不确定,则输出‘?' ,仔细想想,这种情况是不会存在的,因为在 ...

  2. UVA215-Spreadsheet Calculator(模拟+拓扑排序)

    Problem UVA215-Spreadsheet Calculator Accept:401  Submit:2013 Time Limit: 3000 mSec Problem Descript ...

  3. UVA.10305 Ordering Tasks (拓扑排序)

    UVA.10305 Ordering Tasks 题意分析 详解请移步 算法学习 拓扑排序(TopSort) 拓扑排序的裸题 基本方法是,indegree表示入度表,vector存后继节点.在tops ...

  4. UVA 1572 Self-Assembly(拓扑排序)

    1 // 把一个图的所有结点排序,使得每一条有向边(u,v)对应的u都排在v的前面. 2 // 在图论中,这个问题称为拓扑排序.(toposort) 3 // 不难发现:如果图中存在有向环,则不存在拓 ...

  5. Uva 10305 - Ordering Tasks 拓扑排序基础水题 队列和dfs实现

    今天刚学的拓扑排序,大概搞懂后发现这题是赤裸裸的水题. 于是按自己想法敲了一遍,用queue做的,也就是Kahn算法,复杂度o(V+E),调完交上去,WA了... 于是检查了一遍又交了一发,还是WA. ...

  6. UVa 1572 Self-Assembly (拓扑排序)

    题目链接: https://cn.vjudge.net/problem/UVA-1572 Automatic Chemical Manufacturing is experimenting with ...

  7. UVa 10305 - Ordering Tasks (拓扑排序裸题)

    John has n tasks to do. Unfortunately, the tasks are not independent and the execution of one task i ...

  8. POJ——1308Is It A Tree?(模拟拓扑排序判断有向图是否为树)

    Is It A Tree? Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 28399   Accepted: 9684 De ...

  9. UVA 10305 Ordering Tasks(拓扑排序的队列解法)

    题目链接: https://vjudge.net/problem/UVA-10305#author=goodlife2017 题目描述 John有n个任务,但是有些任务需要在做完另外一些任务后才能做. ...

随机推荐

  1. php5权限控制修饰符

    1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...

  2. Oralce中的package和package body

    1.Oracle Package的作用: 可以简化应用设计.提高应用性能.实现信息隐藏.子程序重载 2.ORACLE中的function   .package.package   bodies.pro ...

  3. Linux 文件系统挂载

    文件系统挂载简介  磁盘分区和格式化完成后,磁盘分区要想能够使用,就需要挂载,在挂载某个分区前需要先建立一个挂载点  挂载:将新的文件系统关联至当前根文件系统  卸载:将某文件系统与当前根文件系统的关 ...

  4. c进程学习日志

    #include<unistd.h> #include<sys/types.h> #include<pwd.h> #include<stdio.h> i ...

  5. 关于JWT(Json Web Token)的思考及使用心得

    什么是JWT? JWT(Json Web Token)是一个开放的数据交换验证标准rfc7519(php 后端实现JWT认证方法一般用来做轻量级的API鉴权.由于许多API接口设计是遵循无状态的(比如 ...

  6. hdfs的HA集群搭建的相关配置

    前期准备就不详细说了 .修改Linux主机名 .修改IP .修改主机名和IP的映射关系 ######注意######如果你们公司是租用的服务器或是使用的云主机(如华为用主机.阿里云主机等) /etc/ ...

  7. Qt之滚动字幕

    简述 滚动字幕,也就是传说中的跑马灯效果. ​简单地理解就是:每隔一段时间(一般几百毫秒效果较佳)显示的文字进行变化(即滚动效果). 简述 实现 效果 源码 实现 利用定时器QTimer,在固定的时间 ...

  8. Cannot set web app root system property when WAR file is not expanded

    Cannot set web app root system property when WAR file is not expanded 在tomcat下面可以,在weblogic下面不行的处理方法 ...

  9. (数据结构整理)NJUPT1054

    这一篇博客以一些OJ上的题目为载体,整理一下数据结构.会陆续的更新. .. 我们都知道,数据结构的灵活应用有时能让简化一些题目的解答. 一.栈的应用 1.NJUPT OJ 1054(回文串的推断) 回 ...

  10. 自己封装js组件 - 中级中高级

    接着做关于alert组件的笔记 怎么又出来个中高级呢 对没错 就是出一个中高级来刷流量呵呵呵,但是中高级也不是白叫的 这次主要是增加了widget类,增加了自己绑定的事件和触发事件的方法!这么做是为什 ...