Codeforce 1182B Plus from Picture
时间:2019-06-12
本文章向大家介绍Codeforce 1182B Plus from Picture,主要包括Codeforce 1182B Plus from Picture使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题目链接:http://codeforces.com/problemset/problem/1182/B
题意:检查图中 * 形成的是否是唯一的十字。
思路:找到十字的中心,反向消除十字,最后检查是否有余留的 * ,如果有则图案不正确输出NO。
AC代码:
1 #include<bits/stdc++.h> 2 using namespace std; 3 int n,m; 4 char mp[505][505]; 5 int dx[4] = {0,1,0,-1}; 6 int dy[4] = {-1,0,1,0}; 7 bool check(int x,int y) 8 { 9 if(mp[x][y] != '*')return false; 10 if(mp[x + 1][y] != '*')return false; 11 if(mp[x - 1][y] != '*')return false; 12 if(mp[x][y + 1] != '*')return false; 13 if(mp[x][y - 1] != '*')return false; 14 return true; 15 } 16 void up(int x,int y) 17 { 18 while(mp[x][++y] == '*') mp[x][y] = '.'; 19 } 20 void down(int x,int y) 21 { 22 while(mp[x][--y] == '*') mp[x][y] = '.'; 23 } 24 void left(int x,int y) 25 { 26 while(mp[--x][y] == '*') mp[x][y] = '.'; 27 } 28 void right(int x,int y) 29 { 30 while(mp[++x][y] == '*') mp[x][y] = '.'; 31 } 32 int main() 33 { 34 cin >> n >> m; 35 bool flag = false; 36 for(int i = 0;i < n;i++) 37 { 38 cin >> mp[i]; 39 } 40 for(int i = 0;i < n;i++) 41 { 42 for(int j = 0;j < m;j++) 43 { 44 if(check(i,j)) 45 { 46 mp[i][j] = '.'; 47 up(i,j); 48 down(i,j); 49 left(i,j); 50 right(i,j); 51 flag = true; 52 break; 53 } 54 } 55 if(flag)break; 56 } 57 for(int i = 0;i < n;i++) 58 { 59 for(int j = 0;j < m;j++) 60 { 61 if(mp[i][j] == '*') 62 { 63 flag = false; 64 break; 65 } 66 } 67 } 68 if(flag) cout << "YES"; 69 else cout << "NO"; 70 return 0; 71 } 72 /* 73 5 5 74 ..*.. 75 ..... 76 ..*.. 77 ***** 78 ..*.. 79 */
原文地址:https://www.cnblogs.com/Carered/p/11010271.html
- WebService就是这么简单
- eclipse中hadoop2.3.0环境部署及在eclipse中直接提交mapreduce任务
- spark on yarn提交任务时一直显示ACCEPTED
- 如何恢复hadoop中被删除的文件
- 多个字段中如何按其中两个进行排序(二次排序)
- Hadoop2.3.0上部署Mahout0.10,并测试单机版与分布式版个性化推荐程序
- 总结5种比较高效常用的排序算法
- 曾经做过的40道程序设计课后习题总结(二)
- 曾经做过的40道程序设计课后习题总结(三)
- 曾经做过的40道程序设计课后习题总结(四)
- 二叉树非递归版的后序遍历算法
- 图解用栈数据结构对树的遍历
- 动态规划中篇:爬楼梯
- 动态规划:括号知多少
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- React 中请求远程数据的四种方法
- 数据结构【动态队列】代码实现
- C++抽象工厂
- 数据结构【动态栈】代码实现
- UOS安装chrome谷歌浏览器依赖Fonts-Liberation的问题
- UOS修改盘符名称(像windows的C、D、E盘)
- 【原创】Java并发编程系列29 | ConcurrentLinkedQueue
- UOS系统安装-配置Qt环境
- C++控制台程序接收、解析参数及被如何调用、调试
- C++11标准常用特性---统一初始化
- QPainter的fillRect函数-QGradient-Preset渐变颜色预设值
- 深度学习|Tensorflow2.0进阶
- Mumble——简介及搭建
- 网站开启HSTS增强安全性
- 形式化分析工具(六):HLPSL Tutorial(Example 4,other)