【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

每个图案里面的“洞”的个数都是不同的。
则可以根据这个判别每个图像是什么。
先用dfs确定轮廓之后。
再从每个白点出发dfs,遇到的黑点且没有到达过边界,那么它就是所遇到的黑点里面的“洞”;
计算每个轮廓有多少个"洞"就好

【代码】

#include <bits/stdc++.h>
using namespace std; const int N = 200;
const int dx[5] = {0,0,0,1,-1};
const int dy[5] = {0,1,-1,0,0}; int n,m,a[N+10][N+10],flag[N+10][N+10];//flag>0 black block flag <0 white but visited
int cnt,hole[N*N+10];
char s[N+10][N+10];
int touch;
char duiying[100];
vector <char> v; void cl(int x,int y,int col){
int num = isdigit(s[x][y])?(s[x][y]-'0'):(s[x][y]-'a'+10);
for (int j = col+3;j >= col;j--){
a[x][j] = num&1;
num>>=1;
}
} void dfs(int x,int y){
if (x<0 || x>=n || y<0 || y>=m) return;
if (flag[x][y]!=0) return;
if (a[x][y]==0) return;
flag[x][y] = cnt;
for (int i = 1;i <= 4;i++) dfs(x+dx[i],y+dy[i]);
} void dfs1(int x,int y){
if (x<0 || x>=n || y <0 || y>=m){
touch = -1;
return;
}
if (flag[x][y]==-1) return;
if (flag[x][y]>0){
if (touch!=-1) touch = flag[x][y];
return;
}
flag[x][y] = -1;
for (int i = 1;i <= 4;i++) dfs1(x+dx[i],y+dy[i]);
} int main(){
// freopen("rush.txt","r",stdin);
duiying[1] = 'A',duiying[3] = 'J',duiying[5] = 'D',duiying[4] = 'S',duiying[0] = 'W',duiying[2] = 'K';
int kase = 0;
while (~scanf("%d%d",&n,&m) && n && m){
for (int i = 0;i < n;i++) scanf("%s",s[i]);
for (int i = 0;i < n;i++){
int cnt = 0;
for (int j = 0;j < m;j++){
cl(i,j,cnt);
cnt+=4;
}
}
m*=4;
memset(flag,0,sizeof flag);
cnt = 0;
for (int i = 0;i < n;i++)
for (int j = 0;j < m;j++)
if (a[i][j] && flag[i][j]==0){
++cnt;
dfs(i,j);
}
/*
for (int i = 0;i < n;i++){
for (int j = 0;j < m;j++)
printf("%3d",flag[i][j]);
puts("");
}
*/ memset(hole,0,sizeof hole);
for (int i = 0;i < n;i++)
for (int j = 0;j < m;j++)
if (a[i][j]==0 && flag[i][j]==0){
touch = 0;
dfs1(i,j);
if (touch==-1) continue;
hole[touch]++;
} // printf("hole0=%d\n",hole[0]);
v.clear();
for (int i = 1;i <= cnt;i++)
v.push_back(duiying[hole[i]]);
sort(v.begin(),v.end());
printf("Case %d: ",++kase);
for (int i = 0;i < (int) v.size();i++) putchar(v[i]);
puts("");
}
return 0;
}

【例题 6-13 UVA - 1103】Ancient Messages的更多相关文章

  1. UVa 1103 Ancient Messages(二重深搜)

    In order to understand early civilizations, archaeologists often study texts written in ancient lang ...

  2. Uva 1103 Ancient Messages

    大致思路是DFS: 1. 每个图案所包含的白色连通块数量不一: Ankh : 1 ;  Wedjat : 3  ; Djed : 5   ;   Scarab : 4 ; Was : 0  ;  Ak ...

  3. K - Ancient Messages(dfs求联通块)

    K - Ancient Messages Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Subm ...

  4. 图-用DFS求连通块- UVa 1103和用BFS求最短路-UVa816。

    这道题目甚长, 代码也是甚长, 但是思路却不是太难.然而有好多代码实现的细节, 确是十分的巧妙. 对代码阅读能力, 代码理解能力, 代码实现能力, 代码实现技巧, DFS方法都大有裨益, 敬请有兴趣者 ...

  5. UVa 1339 Ancient Cipher --- 水题

    UVa 1339 题目大意:给定两个长度相同且不超过100个字符的字符串,判断能否把其中一个字符串重排后,然后对26个字母一一做一个映射,使得两个字符串相同 解题思路:字母可以重排,那么次序便不重要, ...

  6. UVa 1103 (利用连通块来判断字符) Ancient Messages

    本题就是灵活运用DFS来求连通块来求解的. 题意: 给出一幅黑白图像,每行相邻的四个点压缩成一个十六进制的字符.然后还有题中图示的6中古老的字符,按字母表顺序输出这些字符的标号. 分析: 首先图像是被 ...

  7. Ancient Messages UVA - 1103

    题目链接:https://vjudge.net/problem/UVA-1103 题目大意:每组数据包含H行W列的字符矩阵(H<=200,W<=50) 每个字符为为16进制  你需要把它转 ...

  8. Ancient Message (古埃及象形文字识别 Uva 1103)

    原题:https://uva.onlinejudge.org/external/11/1103.pdf 给一幅图(16进制), 判断图中有哪些象形文字. 只识别 这6个就可以 示例: 将16进制数据 ...

  9. HDU 3839 Ancient Messages(DFS)

    In order to understand early civilizations, archaeologists often study texts written in ancient lang ...

随机推荐

  1. OpenStack_Swift源代码分析——Object-auditor源代码分析(2)

    1 Object-aduitor审计详细分析 上一篇文章中,解说了Object-aduitor的启动,当中审计的详细运行是AuditorWorker实现的.在run_audit中实例化了Auditor ...

  2. (诡异Floyd&amp;自环)MZ Training 2014 #15 E题(POJ 2240)

    你们见过这么诡异的FLOYD吗? 先上题. [Description] 货币的汇率存在差异.比如,如果1美元购买0.5英镑,1英镑买10法郎.而1法国法郎买0.21美元.然后,通过转换货币,一个聪明的 ...

  3. Android 简述touch事件中的MotionEvent

    有关touchEvent的事件里都有一个 MotionEvent 參数,以下来简介一下它的属性的一些含义和使用的方法 通常单指操作时,一般例如以下: switch (event.getAction() ...

  4. js---12对象创建方式,构造器,原型

    <script type="text/javascript"> var o = {}; var o1 = new Object();//这2种方式创建对象是一样的,因为 ...

  5. Centos7.0 Vmware10.0.3 网络桥接配置

    首先要将Vmware10.0.3设置为桥接模式. CentOS 7.0默认安装好之后是没有自动开启网络连接的! cd  /etc/sysconfig/network-scripts/  #进入网络配置 ...

  6. Easy mock - 安装配置和基本使用

    Easy-mock easy-mock是一款比较好用的接口模拟工具, 使用之前我们需要安装和配置 需要下载的内容有以下 Node Redis MongoDB Node和Redis一路点下一步就行, M ...

  7. 【t038】&&【u214】金字塔

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 小X来到一个雄奇的金字塔挖宝,但是这是一座被诅咒的金字塔,小X必须马上逃离这里,否则小X就会被埋在金字 ...

  8. VmWare 与 宿主主机通信 STEP BY STEP (适用于刚開始学习的人)

    基本原理 在虚拟机中有三种通信方式,例如以下图所看到的 1. Bridged(桥接模式) 在桥接模式下,VMware虚拟出来的操作系统就像是局域网中的一独立的主机,它能够訪问网内不论什么一台机器只是你 ...

  9. 74LS153 选择器 【数字电路】

    74LS153 我用了八个不同频率的方波信号,用153当作信号选择器,控制环节的开关是4通道的选择器,00 01 10 11分别选择通道 0 1 2 3 以下是八选一的demo

  10. JavaScript中的*top、*left、*width、*Height具体解释

    来源:http://www.ido321.com/911.html html代码 1: <body> 2: <div class="father" id=&quo ...