博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVa 11110 - Equidivisions
阅读量:6268 次
发布时间:2019-06-22

本文共 2417 字,大约阅读时间需要 8 分钟。

  题目大意:给一个n*n的矩阵,其中放置n个数字,判断四连通的相同数字的个数是否等于n。

  Flood fill,本来没什么,用dfs判断一下就可以了,可是用scanf读取输入时TLE了,然后看到别人说要用gets()读一整行,因为每行不一定是n对数,好吧,怎么感觉有点坑呢...把字符串解析成数字有没有什么好办法?...

1 #include 
2 #include
3 #include
4 #define MAXN 110 5 6 int mat[MAXN][MAXN]; 7 bool vis[MAXN][MAXN]; 8 int n, cnt; 9 const int dir[4][2] = {
{-1, 0}, {
0, -1}, {
0, 1}, {
1, 0}};10 11 void dfs(int x, int y)12 {13 vis[x][y] = 1;14 cnt++;15 for (int i = 0; i < 4; i++)16 {17 int dx = x + dir[i][0];18 int dy = y + dir[i][1];19 if (dx >= 0 && dx < n && dy >= 0 && dy < n && mat[dx][dy] == mat[x][y] && !vis[dx][dy])20 dfs(dx, dy);21 }22 }23 24 int main()25 {26 #ifdef LOCAL27 freopen("in", "r", stdin);28 #endif29 int x, y;30 char str[10000];31 while (scanf("%d", &n) && n)32 {33 getchar();34 memset(mat, 0, sizeof(mat));35 for (int i = 1; i < n; i++)36 {37 gets(str);38 int len = strlen(str);39 for (int j = 0; j < len; )40 {41 while (j < len && !isdigit(str[j])) j++;42 if (j == len) break;43 x = str[j] - '0';44 j++;45 while (j < len && isdigit(str[j]))46 {47 x = x * 10 + str[j] - '0';48 j++;49 }50 while (j < len && !isdigit(str[j])) j++;51 y = str[j] - '0';52 j++;53 while (j < len && isdigit(str[j]))54 {55 y = y * 10 + str[j] - '0';56 j++;57 }58 mat[x-1][y-1] = i;59 }60 }61 memset(vis, 0, sizeof(vis));62 bool ok = true;63 for (int i = 0; i < n; i++)64 for (int j = 0; j < n; j++)65 if (!vis[i][j])66 {67 cnt = 0;68 dfs(i, j);69 if (cnt != n)70 {71 ok = false;72 goto s;73 }74 }75 s: if (ok) printf("good\n");76 else printf("wrong\n");77 }78 return 0;79 }
View Code

 

转载于:https://www.cnblogs.com/xiaobaibuhei/p/3317690.html

你可能感兴趣的文章
Linux车载系统的开发方向
查看>>
并发编程之五--ThreadLocal
查看>>
摄像头驱动OV7725学习笔记连载(二):0V7725 SCCB时序的实现之寄存器配置
查看>>
iOS播放短的音效
查看>>
[java] java 线程join方法详解
查看>>
JQuery datepicker 用法
查看>>
golang(2):beego 环境搭建
查看>>
天津政府应急系统之GIS一张图(arcgis api for flex)讲解(十)态势标绘模块
查看>>
程序员社交宝典
查看>>
ABP理论学习之MVC控制器(新增)
查看>>
Netty中的三种Reactor(反应堆)
查看>>
网页内容的html标签补全和过滤的两种方法
查看>>
前端源码安全
查看>>
【CodeForces 618B】Guess the Permutation
查看>>
【转】如何实现一个配置中心
查看>>
Docker —— 用于统一开发和部署的轻量级 Linux 容器【转】
查看>>
Threejs 官网 - Three.js 的图形用户界面工具(GUI Tools with Three.js)
查看>>
Atitit.Java exe bat 作为windows系统服务程序运行
查看>>
session的生命周期
查看>>
数据库的本质、概念及其应用实践(二)
查看>>