首页 > ACM题库 > HDU-杭电 > Hdu 1582 AC Again[解题报告] C++
2013
12-12

Hdu 1582 AC Again[解题报告] C++

AC Again

问题描述 :

“AC”这个单词大概是我们 ACMers 最希望听到的回答了。不过如果把它写下来,你还能认识吗?
现在给你一幅由点阵构成的图,它代表 ‘A’ 或 ‘C’ 的一个字母。你的任务就是把它们识别出来。

注意:
1.笔划可能有粗有细,但是我们保证字符在外形上是肉眼可辨别的。
2.我们保证笔划是连贯的,即对于任意一个有笔划的点,在它周围八个点内有一点有笔划,这两点就是相连贯的。
3.’A',’C'这两个字符可能会按90,180,270这样的角度旋转。

输入:

本题目包含多组测试,每两组测试之间用一个或多个空行隔开。
对于每组数据,系统将给你一个肉眼可以辨别的图形表示一个字符’A’ 或 ‘C’。
系统保证每个图形的大小在 50 * 50 一下。
输入数据只包含 ‘ ‘(空格)和’*'两种字符,其中’*'表示该点有笔划。

输出:

对于每组数据,根据图形,在一行内输出 A 或 C。

样例输入:

    *
   * *
  *****
  *   *

  ******
 *
 *
 *
  ******

样例输出:

A
C

#include<string.h>
#include<stdio.h>
#include<iostream>
#include<queue>
using namespace std;
char mp[160][160],c[161];
int f[4][2]={{-1,0},{0,-1},{0,1},{1,0}},len=1,maxlen=0;
struct khp
{
int x,y;
};
void bfs(int x,int y)
{
int i,j;
khp t;
t.x=x;
t.y=y;
queue<khp> k;
k.push(t);
mp[x][y]='*';
while(!k.empty())
{
khp r=k.front();
k.pop();
for(i=0;i<4;i++)
{
int a=f[i][0]+r.x;
int b=f[i][1]+r.y;

if(a>=0&&a<=55&&b>=0&&b<=55&&mp[a][b]!='*')
{
t.x=a;
t.y=b;
mp[a][b]='*';
k.push(t);
}
}
}
}
void init()
{
int i,j;
maxlen=0,len=1;
memset(mp,0,sizeof(mp));
for(i=0;i<55;i++)
mp[0][i]=' ',mp[i][0]=' ';
}
int main()
{
int i,j;
init();
while(gets(c)!=NULL)
{
int w=strlen(c);
if(w==0)
{
bool jd=0;

for(i=0;i<=len&&!jd;i++)
for(j=0;j<=len;j++)
if(mp[i][j]==' ')
{
bfs(i,j);
jd=1;
break;
}
bool judge=0;

for(i=0;i<=maxlen&&!judge;i++)
for(j=0;j<=maxlen;j++)
if(mp[i][j]==' ')
{
judge=1;
break;
}
if(judge) puts("A");
else puts("C");
init();
}
else
{
int l=strlen(c),e=1;
mp[len][0]=' ';
for(i=0;i<l;i++)
mp[len][e++]=c[i];
mp[len++][e]=c[i];
if(l>maxlen) maxlen=l;
memset(c,0,sizeof(c));
}
}
bool jd=0;

for(i=0;i<=100&&!jd;i++)
for(j=0;j<=100;j++)
if(mp[i][j]==' ')
{
bfs(i,j);
jd=1;
break;
}
bool judge=0;

for(i=0;i<=maxlen&&!judge;i++)
for(j=0;j<=maxlen;j++)
if(mp[i][j]==' ')
{
judge=1;
break;
}
if(judge) puts("A");
else puts("C");
return 0;
}

 


  1. Excellent Web-site! I required to ask if I might webpages and use a component of the net web website and use a number of factors for just about any faculty process. Please notify me through email regardless of whether that would be excellent. Many thanks

  2. a是根先忽略掉,递归子树。剩下前缀bejkcfghid和后缀jkebfghicd,分拆的原则的是每个子树前缀和后缀的节点个数是一样的,根节点出现在前缀的第一个,后缀的最后一个。根节点b出现后缀的第四个位置,则第一部分为四个节点,前缀bejk,后缀jkeb,剩下的c出现在后缀的倒数第2个,就划分为cfghi和 fghic,第3部分就为c、c