任意门:http://www.lydsy.com/JudgeOnline/problem.php?id=1562

题目:

对于0,1,…,N-1的N个整数,给定一个距离序列D0,D1,…,DN-1,定义一个变换序列T0,T1,…,TN-1使得每个i,Ti的环上距离等于Di。一个合法的变换序列应是0,1,…,N-1的一个排列,任务是要求出字典序最小的那个变换序列。

题解:

二分建图是显而易见的,可是怎么处理字典序最小?

大神博客:https://www.byvoid.com/blog/noi-2009-transform/

实际倒着做一遍就可以了,正确性显然(只不过我不是这样写的);

先做最大匹配,然后看所匹配的是否为最小标号,不是则强行改值,然后再做最大匹配看是否有完备匹配,无则将值改回。

代码:

 #include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
bool vis[];
int f[],pre[],v[],now[];
int a[],b[];
int n,ans,tot,cc;
void insert(int a, int b)
{
tot++; pre[tot]=now[a]; now[a]=tot; v[tot]=b;
}
bool dfs(int x)
{
if (x<cc) return false;
for (int i=now[x]; i; i=pre[i])
{
if (!vis[v[i]])
{
vis[v[i]]=true;
if (f[v[i]]==- || dfs(f[v[i]]))
{
f[v[i]]=x;
f[x]=v[i];
return true;
}
}
}
return false;
}
int main()
{
int d;
scanf("%d",&n);
tot=;
for (int i=; i<=n; i++)
{
scanf("%d",&d);
a[i]=(i+d) % n;
if (a[i]==) a[i]=n;
b[i]=(i-d);
if (b[i]<)
b[i]+=n;
if (a[i]>b[i])
{
int c;
c=a[i]; a[i]=b[i]; b[i]=c;
}
a[i]+=n; b[i]+=n;
insert(i,a[i]);
insert(i,b[i]);
}
memset(f,-,sizeof(f));
ans=;
for (int i=; i<=n; i++)
{
memset(vis,false,sizeof(vis));
if (dfs(i)) ans++;
}
if (ans<n) { printf("No Answer\n"); return ;}
for (int i=; i<=n; i++)
{
if (f[i]!=a[i])
{
cc=i;
memset(vis,false,sizeof(vis));
int t=f[a[i]];
f[a[i]]=i;
f[b[i]]=-;
vis[a[i]]=true;
if (dfs(t))
{
f[i]=a[i];
}
else
{
f[b[i]]=i;
f[a[i]]=t; }
}
}
for (int i=; i<n; i++)
{
printf("%d ",f[i]-n-);
}
printf("%d\n",f[n]-n-);
return ;
}

bzoj1562[NOI2009]变换序列——2016——3——12的更多相关文章

  1. BZOJ1562: [NOI2009]变换序列(二分图 匈牙利)

    Description Input Output Sample Input 5 1 1 2 2 1 Sample Output 1 2 4 0 3 HINT 30%的数据中N≤50:60%的数据中N≤ ...

  2. [BZOJ1562][NOI2009] 变换序列

    Description Input Output Sample Input 5 1 1 2 2 1 Sample Output 1 2 4 0 3 HINT 30%的数据中N≤50:60%的数据中N≤ ...

  3. BZOJ1562——[NOI2009]变换序列

    1.题意:题意有些难理解 2.分析:我们发现如果要求判断是否合法的话就so easy了,二分图匹配即可,但是我们发现要求输出字典序最小的,那么我们在匈牙利的时候就倒着枚举,另外邻接表中的边一定要排好序 ...

  4. BZOJ1562 [NOI2009]变换序列 【KM算法】

    题目 输入格式 输出格式 输入样例 5 1 1 2 2 1 输出样例 1 2 4 0 3 提示 30%的数据中N≤50: 60%的数据中N≤500: 100%的数据中N≤10000. 题解 每个位置可 ...

  5. Bzoj 1562: [NOI2009]变换序列 匈牙利算法,二分图匹配

    题目: http://cojs.tk/cogs/problem/problem.php?pid=409 409. [NOI2009]变换序列 ★★☆   输入文件:transform.in   输出文 ...

  6. BZOJ 1562 [NOI2009] 变换序列

    [NOI2009] 变换序列 [题解] 就是有一个序列,每个位置可以填两个数,不可重复,问最小字典序. 显然,可以建一个二分图,判合法就是找完美匹配. 那怎么弄最小字典序呢?有好多种解法,我这里给出了 ...

  7. [Luogu 1963] NOI2009 变换序列

    [Luogu 1963] NOI2009 变换序列 先%Dalao's Blog 什么?二分图匹配?这个确定可以建图? 「没有建不成图的图论题,只有你想不出的建模方法.」 建图相当玄学,不过理解大约也 ...

  8. noi2009变换序列

    noi2009变换序列 一.题目 1843 变换序列 2009年NOI全国竞赛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述  ...

  9. Luogu P1963 [NOI2009]变换序列(二分图匹配)

    P1963 [NOI2009]变换序列 题意 题目描述 对于\(N\)个整数\(0,1, \cdots ,N-1\),一个变换序列\(T\)可以将\(i\)变成\(T_i\),其中\(T_i \in ...

随机推荐

  1. zendstudio的安装与配置

    <微信公众平台应用开发实战>第1章搭建开发环境和相关技术介绍,本章会先介绍微信公众平台的一些基本概念和公众平台的开发模式:然后讲解如何搭建开发环境—AppServ和zendstudio:然 ...

  2. mongodb从来没有说它写成功了。

    它只是说,yes,sir. http://www.infoq.com/cn/news/2014/04/bitcoin-banking-mongodb 开头的表述是错误的,官方说法它有4种类型的writ ...

  3. Hibernate的generator属性

    本文讲述Hibernate的generator属性的意义.Generator属性有7种class,本文简略描述了这7种class的意义和用法. <class name="onlyfun ...

  4. Sasha and Array

    Sasha and Array time limit per test 5 seconds memory limit per test 256 megabytes input standard inp ...

  5. brbustoj 1818 石子合并问题--直线版

    比较经典且基础的区间dp,转移方程为 dp_max[i][j] = max(dp_max[i][j],dp_max[i][k] + dp_max[k+1][j] + sum[j]-sum[i-1]); ...

  6. 转:Web测试需要了解的知识

    这里只是介绍Web测试相对于其他类型软件的测试额外需要了解的内容,关于测试方法不是本文的重点,里面谈到的每一项在以后的文章中再说明.大家看到这些内容可能都不陌生,我晒出的内容也许不对或有误导,请大家指 ...

  7. Chapter 1 First Sight——5

    "He's in a wheelchair now," Charlie continued when I didn't respond, 他现在在轮椅上了,没等我回答查理斯就继续说 ...

  8. TCP重传问题解决思路

    处理线上问题经常会碰到网络抖动的情况, 网络抖动有可能就是TCP重传导致,下面简单说下TCP重传的排查思路,不一定能完全解决问题 1. 找运维同事确定是否是网线问题, 如果是网线问题请更换网线 2. ...

  9. JavaScript 逗号表达式

    逗号表达式的一般形式是:表达式1,表达式2,表达式3……表达式n  逗号表达式的求解过程是:先计算表达式1的值,再计算表达式2的值,……一直计算到表达式n的值.最后整个逗号表达式的值是表达式n的值.  ...

  10. after和before的属性妙用

    ::after或::before设置它们的样式时有一个content这个属性这里可以写attr(data-label)其中data-label是标签上设置的data属性里的数据content:attr ...