原题:https://uva.onlinejudge.org/external/11/1103.pdf

给一幅图(16进制), 判断图中有哪些象形文字。

只识别

这6个就可以


示例:

将16进制数据

转换为

二进制数据

然后输出象形文字的名字


原理: 其实很简单,因为这六个象形文字比较特殊,每个文字包含的空心部分个数不一样。

比如Ankh有一个空心部分,Wedjat有3个空心部分。所以只要先用dfs找到象形文字,然后数一数

每个有几个空心部分就可以了。


 #include <cstdio>
#include <cstring>
#include <utility>
#include <set>
#include <algorithm>
#include <vector>
using namespace std; const int MAXN = + ;
bool pic[MAXN][MAXN], record[MAXN][MAXN];
const char *name = "WAKJSD";
int f[MAXN][MAXN], dx[] = {, -, , }, dy[] = {, , -, };
int cnt, H, W, T;
vector<pair<int, int> > startp; void init_read() {
char s[]; cnt = ; H += ; int NW = * W + ;
memset(pic, , sizeof(pic));
memset(f, , sizeof(f));
memset(record, , sizeof(record));
startp.clear();
for (int i = ; i < NW; i++) pic[][i] = pic[H - ][i] = ;
for (int i = ; i < H; i++) pic[i][] = pic[i][NW - ] = ;
for (int i = ; i < H - ; i++) {
scanf("%s", s);
for (int j = ; j < W; j++) {
int num = s[j] > '' ? s[j] - 'a' + : s[j] - '';
for (int k = ; k < ; k++)
if (num >= ( << ( - k))) { pic[i][j * + k + ] = ; num -= ( << ( - k));}
}
}
W = NW;
} void colorization(int x, int y, bool c) {
f[x][y] = cnt;
for (int i = ; i < ; i++) {
int nx = x + dx[i], ny = y + dy[i];
if (nx >= && ny >= && nx < H && ny < W && pic[nx][ny] == c && !f[nx][ny])
colorization(nx, ny, c);
}
}
void floodfill() {
for (int i = ; i < H; i++)
for (int j = ; j < W; j++)
if (!f[i][j]) {
cnt++; colorization(i, j, pic[i][j]);
if (pic[i][j]) startp.push_back(make_pair(i, j));
}
} void get_signiture(set<int> &signature, int x, int y) {
record[x][y] = ;
for (int i = ; i < ; i++) {
int nx = x + dx[i], ny = y + dy[i];
if (nx >= && ny >= && nx < H && ny < W) {
if (f[nx][ny] != f[x][y]) signature.insert(f[nx][ny]);
else if(f[nx][ny] == f[x][y] && !record[nx][ny])
get_signiture(signature, nx, ny);
}
}
}
void recognize() {
vector<char> ans;
int n = startp.size();
for (int i = ; i < n; i++) {
int x = startp[i].first, y = startp[i].second;
set<int> signature;
get_signiture(signature, x, y);
ans.push_back(name[signature.size() - ]);
}
sort(ans.begin(), ans.end());
printf("Case %d: ", ++T);
for (int i = ; i < n; i++)
printf("%c", ans[i]);
printf("\n");
} int main() {
while (scanf("%d%d", &H, &W) == && H) {
init_read();
floodfill();
recognize();
}
return ;
}

Ancient Message (古埃及象形文字识别 Uva 1103)的更多相关文章

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

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

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

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

  3. [uva]AncientMessages象形文字识别 (dfs求连通块)

    非常有趣的一道题目,大意是给你六种符号的16进制文本,让你转化成二进制并识别出来 代码实现上参考了//http://blog.csdn.net/u012139398/article/details/3 ...

  4. Uva 1103 古代象形文字

    题目链接:http://vjudge.net/contest/140550#problem/B 紫书P163. 1.根据16进制图转成2进制图. 每个点dfs一下,马上就把最外围的连通分量编号求出来了 ...

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

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

  6. Uva 1103 Ancient Messages

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

  7. Ancient Messages UVA - 1103

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

  8. 【例题 6-13 UVA - 1103】Ancient Messages

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 每个图案里面的"洞"的个数都是不同的. 则可以根据这个判别每个图像是什么. 先用dfs确定轮廓之后. 再从每个白 ...

  9. uva 1103

    弄懂题意后  其实就是一个dfs /************************************************************************* > Aut ...

随机推荐

  1. C#Socket编程socket.Connect权限出错问题及解决

    最近使用Vs2010编写Socket程序,客户端在调用socket.Connect()时,总是出现: 请求“System.Net.SocketPermission, System, Version=4 ...

  2. 阿里云服务器如何安装memcached

    方法/步骤 1 使用Xshell登陆阿里云服务器. 请使用root帐号登陆.下面的操作全部在home目录里执行 2 安装libevent. 输入命令 yum -y install libevent-d ...

  3. (转载)[FFmpeg]使用ffmpeg从各种视频文件中直接截取视频图片

    你曾想过从一个视频文件中提取图片吗?在Linux下就可以,在这个教程中我将使用ffmpeg来从视频中获取图片. 什么是ffmpeg?What is ffmpeg? ffmpeg是一个非常有用的命令行程 ...

  4. 内存泄漏在 WPF 和 Silverlight 提防

    瑞奇韭菜礼物 ︰ 内存泄漏在 WPF 和 Silverlight 提防 内存泄漏在 WPF 和 Silverlight 提防 WPF 和 Silverlight 允许您定义您的用户界面,用最少的代码将 ...

  5. 浅析angular框架的cookie

    相信接触过网页编程的基本上都知道cookie这个东西吧,一个毫不起眼,但是又十分的重要的东西,今天我们就来分析一下这个小东西,我们都知道客服端通过发送http请求到服务器请求我们的数据,当我们的服务器 ...

  6. 【转】WF事件驱动

    转自:http://www.cnblogs.com/Mayvar/category/315963.html 这系统的教程有代码可以下载 WF事件驱动(5) 摘要: 之前,我通过4篇文章介绍了在WF4中 ...

  7. SGU 188.Factory guard

    模拟 code #include <iostream> #include <cstdio> #define LEN 1000 using namespace std; int ...

  8. java编码转化方案-备用

    import java.io.UnsupportedEncodingException; /** * 转换字符串的编码 */ public class changeCharSet { /** 7位AS ...

  9. Mysql group_concat函数被截断的问题

    mysql group_concat函数被截断的问题   MySQL的 group_concat 函数默认返回1024个字节长度,超过长度的会被截断.最近程序中就遇到这个问题了. 通过如下命令可以查看 ...

  10. 页面加载完成,但ie进度条一直加载

    页面ajax执行完删除等操作,会刷新当前页面,如果前端框架是左右iframe格式 我的前端页面提示用asyncBox,可能iframe和asyncBox的影响,出现这种情况: 网上大多数的说法是 页面 ...