这道题输出特别坑。。。。

题目的意思也不太好理解。。

就解释一下输出吧。。

它让你 从下往上输出。

如果有多种情况,按照字典序从小往大输出。。。

就是这个多种情况是怎么产生的呢。

下面给一组样例。



很明显 A在最底下且A在Z下,Y和这个连通块 没有相交。

答案是:

AYZ

AZY

YAZ

所以题目的意思是让你输出可能的方案。 并不管它是在第几层上。

前几次WA的原因:没有考虑多种情况

后几次WA的原因:把这个块分层以后按照层排好序以后next_permutation

现在看看真是被我自己蠢哭了、、、

最后附一个无解数据吧(把所有结果输出就会超时)

(但是测试数据里没有这样的数据):

15

18

AAABBBCCCDDDEEEFFF

A.AB.BC.CD.DE.EF.F

AAABBBCCCDDDEEEFFF

GGGHHHIIIJJJKKKLLL

G.GH.HI.IJ.JK.KL.L

GGGHHHIIIJJJKKKLLL

MMMNNNOOOPPPQQQRRR

M.MN.NO.OP.PQ.QR.R

MMMNNNOOOPPPQQQRRR

SSSTTTUUUVVVWWWXXX

S.ST.TU.UV.VW.WX.X

SSSTTTUUUVVVWWWXXX

YYYZZZ…………

Y.YZ.Z…………

YYYZZZ…………

// by SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
#define mem(ARRAY,NUM) memset(ARRAY,NUM,sizeof(ARRAY))
using namespace std;
int n,m,tot,N;
char a[30][30],s[30],lm[30],lx[30],rm[30],rx[30],in[30],v[999];
int first[30],next[999];
bool vis[30],map[30][30],VIS[30];
void add(char x,char y){v[tot]=y;next[tot]=first[x];first[x]=tot++;}
void dfs(int t){
if(t==N+1){
for(char i=1;i<=N;i++)printf("%c",s[i]+'A');putchar('\n');
}
for(char i=0;i<26;i++)
if(!in[i]&&vis[i]&&!VIS[i]){
VIS[i]=1,s[t]=i;
for(char j=first[i];~j;j=next[j])in[v[j]]--;
dfs(t+1);
for(char j=first[i];~j;j=next[j])in[v[j]]++;
VIS[i]=0;
}
}
int main(){
while(~scanf("%d%d",&n,&m)){
mem(lm,0x3f);mem(rm,0x3f);mem(first,-1);tot=N=0;
mem(lx,0);mem(rx,0),mem(map,0);mem(vis,0);mem(in,0);
for(char i=1;i<=n;i++)
for(char j=0;j<=m;j++){
scanf("%c",&a[i][j]);
if(a[i][j]!='.'&&a[i][j]!='\n'){
a[i][j]-='A';
if(!vis[a[i][j]])vis[a[i][j]]=1,N++;
lm[a[i][j]]=min(lm[a[i][j]],j);
rm[a[i][j]]=min(rm[a[i][j]],i);
lx[a[i][j]]=max(lx[a[i][j]],j);
rx[a[i][j]]=max(rx[a[i][j]],i);
}
}
for(char i=0;i<26;i++)
if(vis[i]){
for(char j=lm[i];j<=lx[i];j++){
if(a[rm[i]][j]!=i&&!map[a[rm[i]][j]][i])map[a[rm[i]][j]][i]=1;
if(a[rx[i]][j]!=i&&!map[a[rx[i]][j]][i])map[a[rx[i]][j]][i]=1;
}
for(char j=rm[i];j<=rx[i];j++){
if(a[j][lm[i]]!=i&&!map[a[j][lm[i]]][i])map[a[j][lm[i]]][i]=1;
if(a[j][lx[i]]!=i&&!map[a[j][lx[i]]][i])map[a[j][lx[i]]][i]=1;
}
}
for(char i=0;i<26;i++)
for(char j=0;j<26;j++)
if(map[i][j])add(j,i),in[i]++;
dfs(1);
}
}

成功WA了一屏,,,,,,

POJ 1128 Frame Stacking 拓扑排序+暴搜的更多相关文章

  1. POJ 1128 Frame Stacking (拓扑排序)

    题目链接 Description Consider the following 5 picture frames placed on an 9 x 8 array. ........ ........ ...

  2. POJ 1128 Frame Stacking(拓扑排序&#183;打印字典序)

    题意  给你一些矩形框堆叠后的鸟瞰图  推断这些矩形框的堆叠顺序  每一个矩形框满足每边都至少有一个点可见  输入保证至少有一个解 按字典序输出全部可行解 和上一题有点像  仅仅是这个要打印全部的可行 ...

  3. Frame Stacking 拓扑排序 图论

    Description Consider the following 5 picture frames placed on an 9 x 8 array. ........ ........ .... ...

  4. POJ 2367 (裸拓扑排序)

    http://poj.org/problem?id=2367 题意:给你n个数,从第一个数到第n个数,每一行的数字代表排在这个行数的后面的数字,直到0. 这是一个特别裸的拓扑排序的一个题目,拓扑排序我 ...

  5. poj 3687 Labeling Balls(拓扑排序)

    题目:http://poj.org/problem?id=3687题意:n个重量为1~n的球,给定一些编号间的重量比较关系,现在给每个球编号,在符合条件的前提下使得编号小的球重量小.(先保证1号球最轻 ...

  6. [ACM] POJ 3687 Labeling Balls (拓扑排序,反向生成端)

    Labeling Balls Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10161   Accepted: 2810 D ...

  7. poj 2762(强连通分量+拓扑排序)

    题目链接:http://poj.org/problem?id=2762 题意:给出一个有向图,判断任意的两个顶点(u,v)能否从u到达v,或v到达u,即单连通,输出Yes或No. 分析:对于同一个强连 ...

  8. POJ 2585.Window Pains 拓扑排序

    Window Pains Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1888   Accepted: 944 Descr ...

  9. POJ 1270 Following Orders 拓扑排序

    http://poj.org/problem?id=1270 题目大意: 给你一串序列,然后再给你他们部分的大小,要求你输出他们从小到大的所有排列. 如a b f g 然后 a<b ,b< ...

随机推荐

  1. 前端-JS思维导图

    看不清的朋友右键保存或者新窗口打开哦!喜欢我可以关注我,还有更多前端思维导图笔记

  2. WebService 服务接口

    天气预报Web服务,数据来源于中国气象局Endpoint :http://www.webxml.com.cn/WebServices/WeatherWebService.asmxDisco :http ...

  3. spring过滤器篇

    CharacterEncodingFilter spring的web包下的一个过滤器,用于设置程序的字符编码,它有两个参数encoding和forceEncoding. encoding:字符集,将过 ...

  4. 读书笔记「Python编程:从入门到实践」_2.变量和简单数据类型

    做了大半年RPA了,用的工具是Kapow. 工作没有那么忙,不想就这么荒废着,想学点什么.就Python吧. 为期三个月,希望能坚持下来. 2.1 变量的命名和使用 变量名只能包含字母.数字和下划线. ...

  5. 如何在CorelDRAW中创建对象阴影

    阴影工具可以为对象创建光线映射的阴影效果,使对象产生较强的立体感.可以为大多数对象或群组对象添加阴影,其中包括美术字.段落文本和位图.创建对象阴影可以增加视觉层次,使图形更加逼真. CorelDRAW ...

  6. rabbitmq基本原理(转载)

    Rabbitmq基本原理(转载) MQ全称为Message Queue, 是一种分布式应用程序的的通信方法,它是消费-生产者模型的一个典型的代表,producer往消息队列中不断写入消息,而另一端co ...

  7. 训练1-T

    一个正整数,如果它能被7整除,或者它的十进制表示法中某个位数上的数字为7,则称其为与7相关的数.求所有小于等于N的与7无关的正整数的平方和. 例如:N = 8,<= 8与7无关的数包括:1 2 ...

  8. Django入门--模板变量、过滤器及静态文件

    一.模板变量 我们登录页面后,在页面上会显示姓名等信息,姓名就是模板变量,用来显示登陆者的名字,Django对这些数据进行处理后,返回给前端页面,前端页面进行渲染. 1.模板变量语法规则 1)在htm ...

  9. PHP开发实战权威指南-读书总结

    从今年开始,断断续续学习PHP已经有4个月了.最初,认真学习PHP几天,就弄WordPress搭建了一个个人博客,这也符合技术人的实践理念. 最近,重温PHP开发实战权威指南,做点总结,整理下自己学习 ...

  10. 邓_ php SESSION

    学会php session可以在很多地方使用,比如做一个后台登录的功能,要让程序记住用户的session,其实很简单,看了下面的文章你就明白了. PHP session用法其实很简单它可以把用户提交的 ...