一道很水的topsort,唉?怎么交了14遍...(某人用我的代码刚好卡过,我怎么过不去...【鄙视】【鄙视】【鄙视】)

#include <bits/stdc++.h>

using namespace std;

#define INF 0x3f3f3f3f
#define MAXN 1000010
#define MAXM 5010 int n,m,len = ,tot = ,lin[MAXN],top = ,a[],vis[],in[];
char ch[][];
string st[MAXN],s1;
struct node
{
int ix,iy;
int ax,ay;
}q[];
struct edge
{
int y,next;
}e[MAXN]; inline void add(int xx,int yy)
{
e[++tot].y = yy;
e[tot].next = lin[xx];
lin[xx] = tot;
} void DFS(string xx,int le)
{
if(le == len + )
{
st[++top] = xx;
return ;
}
for(int k = ;k <= len;++k)
{
int i = a[k];
if(vis[i] && in[i] == )
{
vis[i] = false;
for(int j = lin[i],y;j;j = e[j].next)
in[y = e[j].y]--;
DFS((xx + (char)(i + 'A' - )),le + );
vis[i] = true;
for(int j = lin[i],y;j;j = e[j].next)
in[y = e[j].y]++;
}
}
} namespace ls {
inline int kmax(int a, int b) { return a > b ? a : b; }
inline int kmin(int a, int b) { return a > b ? b : a; }
} int main()
{
scanf("%d %d", &n, &m);
for(int i = ;i <= ;++i)
q[i].ix = INF,q[i].iy = INF;
for(int i = ;i <= n;++i)
{
for(int j = ;j <= m;++j)
{
cin >> ch[i][j];
if(ch[i][j] == '.') continue;
int num = (int)ch[i][j] - 'A' + ;
if(!vis[num])
{
vis[num] = true;
a[++len] = num;
}
q[num].ix = ls::kmin(i,q[num].ix);
q[num].iy = ls::kmin(j,q[num].iy);
q[num].ax = ls::kmax(i,q[num].ax);
q[num].ay = ls::kmax(j,q[num].ay);
}
}
for(int ii = ;ii <= len;++ii)
{
int num = a[ii];
char c = (char)(num + 'A' - );
for(int i = q[num].ix;i <= q[num].ax;++i)
{
if(ch[i][q[num].iy] != c)
{
int numm = ch[i][q[num].iy] - 'A' + ;
in[numm]++;
add(num,numm);
}
if(ch[i][q[num].ay] != c)
{
int numm = ch[i][q[num].ay] - 'A' + ;
in[numm]++;
add(num,numm);
}
}
for(int i = q[num].iy + ;i <= q[num].ay - ;++i)
{ if(ch[q[num].ix][i] != c)
{
int numm = ch[q[num].ix][i] - 'A' + ;
in[numm]++;
add(num,numm);
}
if(ch[q[num].ax][i] != c)
{
int numm = ch[q[num].ax][i] - 'A' + ;
in[numm]++;
add(num,numm);
}
}
}
DFS(s1,);
sort(st + ,st + top + );
for(int i = ;i <= top;++i)
cout << st[i] << endl;
return ;
}

以下代码会很快↓↓↓

#include <bits/stdc++.h>
#define INF ((int)(1e9))
#define LINF ((ll)(1e18))
#define pb push_back
#define mp make_pair
#define ll long long
#define _tp template
#define _tyn typename
#define ull unsigned ll
#define pii pair<int,int>
#define uint unsigned int
#define ms(_data) memset(_data,0,sizeof(_data))
#define fin(_filename) freopen(_filename,"r",stdin)
#define fout(_filename) freopen(_filename,"w",stdout)
#define msn(_data,_num) memset(_data,_num,sizeof(_data))
using namespace std;
_tp<_tyn T>void mymax( T &_a , T _b ){ if( _a < _b ) _a = _b; }
_tp<_tyn T>void mymin( T &_a , T _b ){ if( _a > _b ) _a = _b; }
int getnum(){
char ch = '.';
int fu = ;
while( ch < '' || ch > '' ){
ch = getchar();
if( ch == '-' ) fu = -;
}
int ret = ;
while( ch >= '' && ch <= '' ){
ret = ret * + (ch-'');
ch = getchar();
}
return ret;
}
char getlet(){
char ch = '%';
while( ( ch < 'A' || ch > 'Z' ) && ch != '.' ) ch = getchar();
return ch;
}
void read( int &x, int &y ){
x = getnum(); y = getnum();
}
void read( char &c ){
c = getlet();
}
/////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////
#define MAXN 40
struct Pos{
int y,x;
Pos(){}
Pos( int yy , int xx ){
y = yy;
x = xx;
}
};
int n,m;
int data[MAXN][MAXN];
Pos ld[MAXN],ur[MAXN];
bool exist[MAXN]; //检测一个矩形是否完整
bool test( int x ){
for( int i = ld[x].x ; i <= ur[x].x ; i++ ){
if( data[ld[x].y][i] != x && data[ld[x].y][i] != - ) return ;
if( data[ur[x].y][i] != x && data[ur[x].y][i] != - ) return ;
}
for( int i = ur[x].y ; i <= ld[x].y ; i++ ){
if( data[i][ld[x].x] != x && data[i][ld[x].x] != - ) return ;
if( data[i][ur[x].x] != x && data[i][ur[x].x] != - ) return ;
}
return ;
}
//消除一个矩形
void seton( int x , int a ){
for( int i = ld[x].x ; i <= ur[x].x ; i++ ){
data[ld[x].y][i] = a;
data[ur[x].y][i] = a;
}
for( int i = ur[x].y ; i <= ld[x].y ; i++ ){
data[i][ld[x].x] = a;
data[i][ur[x].x] = a;
}
} vector<string> ans;
void dfs( string now ){
bool gao = ;
for( int i = ; i < ; i++ ){
if( !exist[i] ) continue;
if( !test(i) ) continue;
gao = ;
exist[i] = ;
int ls[MAXN][MAXN];
memcpy(ls,data,sizeof(ls));
seton(i,-);
dfs( now + (char)(i+'A') );
memcpy(data,ls,sizeof(data));
exist[i] = ;
}
if( gao ) return;
reverse(now.begin(),now.end());
ans.pb(now);
}
int main(){
//fin("frameup.in");
//fout("frameup.out");
for( int i = ; i < ; i++ ){
ld[i].y = ; ld[i].x = INF;
ur[i].y = INF; ur[i].x = ;
}
msn(data,-);
ms(exist); read(n,m);
for( int i = ; i <= n ; i++ ){
for( int j = ; j <= m ; j++ ){
char c; read(c);
if( c == '.' ) continue;
data[i][j] = c-'A';
exist[data[i][j]] = ;
//记录矩形左下角、右上角坐标
mymax( ld[data[i][j]].y , i );
mymin( ld[data[i][j]].x , j );
mymin( ur[data[i][j]].y , i );
mymax( ur[data[i][j]].x , j );
}
}
dfs("");
//整理答案
sort(ans.begin(),ans.end());
for( uint i = ; i < ans.size() ; i++ )
cout << ans[i] << endl; return ;
}

P1228-重叠的图像的更多相关文章

  1. [Android] 给图像加入相框、圆形圆角显示图片、图像合成知识

        前一篇文章讲述了Android触屏setOnTouchListener实现突破缩放.移动.绘制和加入水印,继续我的"随手拍"项目完毕给图片加入相框.圆形圆角显示图片和图像合 ...

  2. Gram-Schmidt图像融合

    遥感图像融合的定义是通过将多光谱低分辨率的图像和高分辨率的全色波段进行融合从而得到信息量更丰富的遥感图像.常用的遥感图像融合方法有Brovey\PCA\Gram-Schmidt方法.其中Gram-Sc ...

  3. 什么是Alpha通道?

    图像处理(Alpha通道,RGB,...)祁连山(Adobe 系列教程)****的UI课程 一个也许很傻的问题,在图像处理中alpha到底是什么?  Alpha通道是计算机图形学中的术语,指的是特别的 ...

  4. 【图像处理】ISP 图像传感器camera原理

    1.Color Filter Array — CFA 随着数码相机.手机的普及,CCD/CMOS 图像传感器近年来得到广泛的关注和应用. 图像传感器一般都采用一定的模式来采集图像数据,常用的有 BGR ...

  5. Htmlt_Div+Css简介

    DIV+CSS是网站标准(或称“WEB标准”)中常用术语之一,通常为了说明与HTML网页设计语言中的表格(table)定位方式的区别,因为XHTML网站设计标准中,不再使用表格定位技术,而是采用DIV ...

  6. 关于automatic_Panoramic_Image_Stitching_using_Invariant_features 的阅读笔记

    并没有都读完,不过感觉还是有必要做一个笔记的,毕竟这只是随笔不是文章,所以可以有多少写多少,也算是工作总结了,最重要的是这个好在可以,完成所有有意义文档的检索,比起自己的word来说高级很多~~~. ...

  7. GDI+ —— Tcanvas 类属性及方法.......

    delphi TCanvas类 类关系   TObject-> TPersistent   对那些作图对象,可使用TCanvas对象作为画布.标准的window控件,例如编辑控件和列表框控件,当 ...

  8. Android bitmap图片处理

    一.View转换为Bitmap         在Android中所有的控件都是View的直接子类或者间接子类,通过它们可以组成丰富的UI界面.在窗口显示的时候Android会把这些控件都加载到内存中 ...

  9. opencv如何用模板匹配寻找目标

    首先使用: MatchTemplate 比较模板和重叠的图像区域 void cvMatchTemplate( const CvArr* image, const CvArr* templ, CvArr ...

  10. canvas扩散圆环

    最近看了很多牛的动画,想想自己的canvas的确很菜. 公式在那里,但是不是太会套.找demo发现都是很难的 于是找了个简单的效果 圆环从中间扩散的效果 关键是 globalCompositeOper ...

随机推荐

  1. 【LeetCode从零单排】No 114 Flatten Binary Tree to Linked List

    题目 Given a binary tree, flatten it to a linked list in-place. For example,Given 1 / \ 2 5 / \ \ 3 4 ...

  2. Task C# 多线程和异步模型 TPL模型 【C#】43. TPL基础——Task初步 22 C# 第十八章 TPL 并行编程 TPL 和传统 .NET 异步编程一 Task.Delay() 和 Thread.Sleep() 区别

    Task C# 多线程和异步模型 TPL模型   Task,异步,多线程简单总结 1,如何把一个异步封装为Task异步 Task.Factory.FromAsync 对老的一些异步模型封装为Task ...

  3. (转)gcc学习笔记

    1.gcc -Wall hello.c -o hello //编译源文件,显示警告信息 2../a.out   //运行程序 3.gcc -Wall calc.c /usr/lib/libm.a -o ...

  4. easyUI datagrid组件能否有display:none的隐藏效果

    这个项目用了JQ easyUI datagrid 组件,我今天做了一个页面,页面有个div层,div里放了一个easyUI datagrid,页面初始化时div隐藏(display:none),通过点 ...

  5. Fairy Tail - Main Theme Slow Version guitar (solo)

    Хвост Феи animelodies1 (on youtube) Переписал jarrro (on vk.com)

  6. MUI-折叠面板效果accordion

    在做开发的过程中我们经经常使用到折叠面板. 那我们来看下折叠面板到底是怎么使用. 废话不多说. 代码粘下来: <!DOCTYPE html> <html> <head&g ...

  7. STM32的低功耗设置

    因为产品需求,系统功耗是一个很重要的考虑方面.好好看下STM32F103的低功耗问题,以便编写驱动. 1.STM32的电源 1.1 STM32电源框图 上面的电源中需要注意的是后备供电区域,这个部分由 ...

  8. matlab max函数

    >> a=[1,6,3;7,5,6] a = 1 6 3 7 5 6 >> [q,p]=max(a,[],2) 返回每行最大值,q是结果.p是索引 q = 6 7 p = 2 ...

  9. 微信公众号菜单与应用交互session

    http://www.cnblogs.com/yank/p/3476874.html http://blog.csdn.net/zmhawk/article/details/43671195 http ...

  10. GPS常见故障

    当出现故障时,依据可能原因进行排查. 下表列举典型故障及调试方法 现象 root cause 检查 实验   GPS无法开启/无法搜星 软件配置错误 SW 相关配置(如GPIO等) 录制mobile ...