POJ 1128 Frame Stacking 拓扑排序+暴搜
这道题输出特别坑。。。。
题目的意思也不太好理解。。
就解释一下输出吧。。
它让你 从下往上输出。
如果有多种情况,按照字典序从小往大输出。。。
就是这个多种情况是怎么产生的呢。
下面给一组样例。
很明显 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 拓扑排序+暴搜的更多相关文章
- POJ 1128 Frame Stacking (拓扑排序)
题目链接 Description Consider the following 5 picture frames placed on an 9 x 8 array. ........ ........ ...
- POJ 1128 Frame Stacking(拓扑排序·打印字典序)
题意 给你一些矩形框堆叠后的鸟瞰图 推断这些矩形框的堆叠顺序 每一个矩形框满足每边都至少有一个点可见 输入保证至少有一个解 按字典序输出全部可行解 和上一题有点像 仅仅是这个要打印全部的可行 ...
- Frame Stacking 拓扑排序 图论
Description Consider the following 5 picture frames placed on an 9 x 8 array. ........ ........ .... ...
- POJ 2367 (裸拓扑排序)
http://poj.org/problem?id=2367 题意:给你n个数,从第一个数到第n个数,每一行的数字代表排在这个行数的后面的数字,直到0. 这是一个特别裸的拓扑排序的一个题目,拓扑排序我 ...
- poj 3687 Labeling Balls(拓扑排序)
题目:http://poj.org/problem?id=3687题意:n个重量为1~n的球,给定一些编号间的重量比较关系,现在给每个球编号,在符合条件的前提下使得编号小的球重量小.(先保证1号球最轻 ...
- [ACM] POJ 3687 Labeling Balls (拓扑排序,反向生成端)
Labeling Balls Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10161 Accepted: 2810 D ...
- poj 2762(强连通分量+拓扑排序)
题目链接:http://poj.org/problem?id=2762 题意:给出一个有向图,判断任意的两个顶点(u,v)能否从u到达v,或v到达u,即单连通,输出Yes或No. 分析:对于同一个强连 ...
- POJ 2585.Window Pains 拓扑排序
Window Pains Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1888 Accepted: 944 Descr ...
- POJ 1270 Following Orders 拓扑排序
http://poj.org/problem?id=1270 题目大意: 给你一串序列,然后再给你他们部分的大小,要求你输出他们从小到大的所有排列. 如a b f g 然后 a<b ,b< ...
随机推荐
- javascript中经典继承的兼容写法
function create(obj) { // 2.1 判断浏览器支持不支持 Object.create // 如果支持,直接使用 Object.create // 如果不支持,自己实现 if(O ...
- 解决java float double 浮点型参与计算失精度
本人前段时间做一个社区电商应用,发现了一个 天坑 ...................让我哭会 . 下面听听我的踩坑之路吧 ,电商肯定跟¥打交道了,计算少不了的.由于本人太菜 单纯的以为 fl ...
- 开发一款合格的APP成本费用大概是多少?
随着移动互联网的发展,APP开发已经成了当下最热门的话题.无数人都盼望做出下一个微信.滴滴打车等等神奇的APP软件.如今,APP开发门槛已经非常低,媒体上也充斥着各种小团队创造奇迹的故事.不过,APP ...
- CSV文件模块的使用
---恢复内容开始--- 1.CSV模块使用流程 1.导入模块 impport CSV 2.打开文件(xxx.csv) with open('xxx.csv','a',encoding='utf-8' ...
- openlayers5学习笔记-添加Overlay
tmp.addPosition = function (map, item) { var ele = document.createElement("div"); var img ...
- Django01 web http 基础
一.内容回顾 1.python基础 2.网络编程 3.并发编程 4.前端 5.数据库(MySQL) 二.今日概要 1.了解Web应用程序的本质 2.Django简介及安装使用 三.今日详细 1.最简单 ...
- 路飞学城Python-Day186
Evernote Export 持续集成 持续集成,简单的说就是持续集成频繁的将代码集成到主干,它的好处主要有1.快速发现错误,没完成一点更新,就集成到主干,可以快速发现错误,定位错误也会比较容易,2 ...
- XSS Chanllenges 1-5
XSS Chanllenges XSS Chanllenges 是一个XSS的练习平台,可以借助这个平台练习各种绕过,以及手工进行XSS的学习 平台链接:https://xss-quiz.int21h ...
- 使用requests爬取小说
实现: import requests import re import time def get_chapter(aim_url): ''' 获取小说章节名称和对应的url地址 :param aim ...
- log4j 设置日志输出文件的路径
log4j.rootLogger=debug, A1 #输出到指定目录下 og4j.appender.A1.File=/log.log #输出到tomcat容器下的指定目录 log4j.appende ...