Educational Codeforces Round 26 Problem B
B. Flag of Berlandtime limit per test1 second
memory limit per test256 megabytes
inputstandard input
outputstandard output
The flag of Berland is such rectangular field n × m that satisfies following conditions:
- Flag consists of three colors which correspond to letters 'R', 'G' and 'B'.
- Flag consists of three equal in width and height stripes, parralel to each other and to sides of the flag. Each stripe has exactly one color.
- Each color should be used in exactly one stripe.
You are given a field n × m, consisting of characters 'R', 'G' and 'B'. Output "YES" (without quotes) if this field corresponds to correct flag of Berland. Otherwise, print "NO" (without quotes).
InputThe first line contains two integer numbers n and m (1 ≤ n, m ≤ 100) — the sizes of the field.
Each of the following n lines consisting of m characters 'R', 'G' and 'B' — the description of the field.
OutputPrint "YES" (without quotes) if the given field corresponds to correct flag of Berland . Otherwise, print "NO" (without quotes).
Examplesinput6 5
RRRRR
RRRRR
BBBBB
BBBBB
GGGGG
GGGGGoutputYESinput4 3
BRG
BRG
BRG
BRGoutputYESinput6 7
RRRGGGG
RRRGGGG
RRRGGGG
RRRBBBB
RRRBBBB
RRRBBBBoutputNOinput4 4
RRRR
RRRR
BBBB
GGGGoutputNONoteThe field in the third example doesn't have three parralel stripes.
Rows of the field in the fourth example are parralel to each other and to borders. But they have different heights — 2, 1 and 1.
题目大意还不是很好表达。就是看能不能分成均等的三份;
只要遍历一遍就好了。
模拟吧,代码有点长
1 #include<iostream>
2 #include<stdio.h>
3 using namespace std;
4 char a[105][105];
5 int hang(int n,int m){ //验证行是否分成了三份
6 char fir=a[1][1],sec=a[n/3+1][1],three=a[n][1];
7 if(fir==sec||fir==three||sec==three){
8 return false;
9 }
10 for(int i=1;i<=n;i++){
11 for(int j=1;j<=m;j++){
12 if(i<=n/3){
13 if(a[i][j]!=fir){
14 return false;
15 }
16 }else if(i<=2*(n/3)){
17 if(a[i][j]!=sec){
18 return false;
19 }
20 }else{
21 if(a[i][j]!=three){
22 return false;
23 }
24 }
25 }
26 }
27 return true;
28 }
29 int lie(int n,int m){ //验证列是否分成三份
30 char fir=a[1][1],sec=a[1][m/3+1],three=a[1][m];
31 if(fir==sec||fir==three||sec==three){
32 return false;
33 }
34 for(int i=1;i<=n;i++){
35 for(int j=1;j<=m;j++){
36 if(j<=m/3){
37 if(a[i][j]!=fir){
38 return false;
39 }
40 }else if(j<=2*(m/3)){
41 if(a[i][j]!=sec){
42 return false;
43 }
44 }else{
45 if(a[i][j]!=three){
46 return false;
47 }
48 }
49 }
50 }
51 return true;
52 }
53 int main(){
54 int m,n;
55 cin>>n>>m;
56 for(int i=1;i<=n;i++){
57 for(int j=1;j<=m;j++){
58 cin>>a[i][j];
59 }
60 }
61 if(n%3!=0&&m%3!=0){
62 cout<<"NO"<<endl;
63 }else{
64 if(n%3==0&&m%3==0){
65 if(hang(n,m)||lie(n,m)){
66 cout<<"YES"<<endl;
67 }else{
68 cout<<"NO"<<endl;
69 }
70 }else if(n%3==0){
71 if(hang(n,m)){
72 cout<<"YES"<<endl;
73 }else{
74 cout<<"NO"<<endl;
75 }
76 }else{
77 if(lie(n,m)){
78 cout<<"YES"<<endl;
79 }else{
80 cout<<"NO"<<endl;
81 }
82 }
83 }
84 return 0;
85 }
Educational Codeforces Round 26 Problem B的更多相关文章
- Educational Codeforces Round 26
Educational Codeforces Round 26 困到不行的场,等着中午显示器到了就可以美滋滋了 A. Text Volume time limit per test 1 second ...
- CodeForces 837F - Prefix Sums | Educational Codeforces Round 26
按tutorial打的我血崩,死活挂第四组- - 思路来自FXXL /* CodeForces 837F - Prefix Sums [ 二分,组合数 ] | Educational Codeforc ...
- CodeForces - 837E - Vasya's Function | Educational Codeforces Round 26
/* CodeForces - 837E - Vasya's Function [ 数论 ] | Educational Codeforces Round 26 题意: f(a, 0) = 0; f( ...
- CodeForces 837D - Round Subset | Educational Codeforces Round 26
/* CodeForces 837D - Round Subset [ DP ] | Educational Codeforces Round 26 题意: 选k个数相乘让末尾0最多 分析: 第i个数 ...
- Educational Codeforces Round 32 Problem 888C - K-Dominant Character
1) Link to the problem: http://codeforces.com/contest/888/problem/C 2) Description: You are given a ...
- Educational Codeforces Round 26 [ D. Round Subset ] [ E. Vasya's Function ] [ F. Prefix Sums ]
PROBLEM D - Round Subset 题 OvO http://codeforces.com/contest/837/problem/D 837D 解 DP, dp[i][j]代表已经选择 ...
- Educational Codeforces Round 26 B,C
B. Flag of Berland 链接:http://codeforces.com/contest/837/problem/B 思路:题目要求判断三个字母是否是条纹型的,而且宽和高相同,那么先求出 ...
- Educational Codeforces Round 21 Problem E(Codeforces 808E) - 动态规划 - 贪心
After several latest reforms many tourists are planning to visit Berland, and Berland people underst ...
- Educational Codeforces Round 21 Problem D(Codeforces 808D)
Vasya has an array a consisting of positive integer numbers. Vasya wants to divide this array into t ...
- Educational Codeforces Round 21 Problem A - C
Problem A Lucky Year 题目传送门[here] 题目大意是说,只有一个数字非零的数是幸运的,给出一个数,求下一个幸运的数是多少. 这个幸运的数不是最高位的数字都是零,于是只跟最高位有 ...
随机推荐
- WPF学习 - 自定义Panel
WPF中的Panel(面板),是继承自FrameworkElement的抽象类,表示一个可以用来排列子元素的面板. 在WPF中,一种预设了几种常用的面板,如Grid.StackPanel.WrapPa ...
- 在 Net7.0环境下通过反射创建泛型实例和调用泛型方法
一.介绍 最近没事干,就用闲暇时间写点东西,也记录一下温习历程.老人说的好,好记性,不如烂笔头.时间一长,当时记忆的再清楚,都会变得模糊,索性就写博客记录下来,如果下次需要,直接打开博客就找到了,不用 ...
- Avalonia开发(二)项目结构解析
一.前言 在Avalonia开发(一)环境搭建 文章中介绍了Avalonia的介绍.开发环境的搭建.项目创建,以及项目FirstAvaloniaApp项目结构的介绍.本篇文章将介绍各平台的项目介绍. ...
- 聊一聊 TLS/SSL
哈喽大家好,我是咸鱼 当我们在上网冲浪的时候,会在浏览器界面顶部看到一个小锁标志,或者网址以 "https://" 开头 这意味着我们正在使用 TLS/SSL 协议进行安全通信.虽 ...
- 浅谈TCP协议的发生过程
1. TCP协议 1.1 TCP协议的性质 面向连接的.可靠的.基于字节流 至于为什么面向连接,又为什么可靠,基于字节流的,等后面便可知道. 1.2 TCP协议栈收发数据的四个阶段 创建套接字 连接服 ...
- C51单片机开发
C51单片机开发笔记 定时器 C51中的定时器和计数器是同一个硬件电路支持的,通过寄存器配置不同,就可以将他当做定时器 或者计数器使用. 确切的说,定时器和计数器区别是致使他们背后的计数存储器加1的信 ...
- linux常用命令(七)
用于系统内信息交流的相关命令 echo mesg wall write echo:在显示器上显示文字 命令语法:echo[选项] [字符串] 选项 选项含义 -n 表示输出文字后不换行 例子:将文本& ...
- Composite 组合模式简介与 C# 示例【结构型3】【设计模式来了_8】
〇.简介 1.什么是组合设计模式? 一句话解释: 针对树形结构的任意节点,都实现了同一接口,他们具有相同的操作,可以通过某一操作来遍历全部节点. 组合模式通过使用树形结构来组合对象,用来表示部分以 ...
- Redis 6 学习笔记 4 —— 通过秒杀案例,学习并发相关和apache bench的使用,记录遇到的问题
背景 这是某硅谷的redis案例,主要问题是解决计数器和人员记录的事务操作 按照某硅谷的视频敲完之后出现这样乱码加报错的问题 乱码的问题要去tomcat根目录的conf文件夹下修改logging.pr ...
- 红瞳瞳CRUD Avue各参数作用
常用的两个avue文档: avue 开发文档: https://www.bookstack.cn/read/avue-2.x/3c22e1c01099c1f1.md avue开发指南:https: ...