16:矩阵剪刀石头布
时间:2022-05-07
本文章向大家介绍16:矩阵剪刀石头布,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
16:矩阵剪刀石头布
总时间限制: 5000ms 内存限制: 65536kB描述
Bart的妹妹Lisa在一个二维矩阵上创造了新的文明。矩阵上每个位置被三种生命形式之一占据:石头,剪刀,布。每天,上下左右相邻的不同生命形式将会发生战斗。在战斗中,石头永远胜剪刀,剪刀永远胜布,布永远胜石头。每一天结束之后,败者的领地将被胜者占领。
你的工作是计算出n天之后矩阵的占据情况。
输入第一行包含三个正整数r,c,n,分别表示矩阵的行数、列数以及天数。每个整数均不超过100。 接下来r行,每行c个字符,描述矩阵初始时被占据的情况。每个位置上的字符只能是R,S,P三者之一,分别代表石头,剪刀,布。相邻字符之间无空格。输出输出n天之后的矩阵占据情况。每个位置上的字符只能是R,S,P三者之一,相邻字符之间无空格。样例输入
3 3 1
RRR
RSR
RRR
样例输出
RRR
RRR
RRR
来源Waterloo local 2003.01.25
1 #include<cstdio>
2 #include<cstring>
3 #include<iostream>
4 using namespace std;
5
6 char a[110][110],b[110][110];
7 int n,m,t;
8
9 int main()
10 {
11 cin >> n >> m >> t;
12 for(int i=1;i<=n;i++)
13 for(int j=1;j<=m;j++)
14 {
15 cin>>a[i][j];
16 b[i][j]=a[i][j];
17 }
18 for(int k=1;k<=t;k++)
19 {
20 for(int i=1;i<=n;i++)
21 for(int j=1;j<=m;j++)
22 {
23 if(a[i][j]=='R')
24 {
25 if(a[i-1][j]=='S')b[i-1][j]='R';
26 if(a[i+1][j]=='S')b[i+1][j]='R';
27 if(a[i][j-1]=='S')b[i][j-1]='R';
28 if(a[i][j+1]=='S')b[i][j+1]='R';
29 }
30 if(a[i][j]=='S')
31 {
32 if(a[i-1][j]=='P')b[i-1][j]='S';
33 if(a[i+1][j]=='P')b[i+1][j]='S';
34 if(a[i][j-1]=='P')b[i][j-1]='S';
35 if(a[i][j+1]=='P')b[i][j+1]='S';
36 }
37 if(a[i][j]=='P')
38 {
39 if(a[i-1][j]=='R')b[i-1][j]='P';
40 if(a[i+1][j]=='R')b[i+1][j]='P';
41 if(a[i][j-1]=='R')b[i][j-1]='P';
42 if(a[i][j+1]=='R')b[i][j+1]='P';
43 }
44 }
45 for(int i=1;i<=n;i++)
46 for(int j=1;j<=m;j++)
47 a[i][j]=b[i][j];
48 }
49 for(int i=1;i<=n;i++)
50 {
51 for(int j=1;j<=m;j++)
52 cout << b[i][j];
53 cout << "n";
54 }
55 return 0;
56 }
- 一款不可多得的火柴时钟
- 常见端口转发工具的使用方式(二)
- 如何在CDH启用Kerberos的情况下安装及使用Sentry(一)
- 打造炫酷的通知插件EasyToaster
- 世界智能驾驶挑战赛信息安全组——新人扫盲
- 如何在CDH启用Kerberos的情况下安装及使用Sentry(二)
- 如何用 vue 制作一个探探滑动组件
- 常见端口转发工具的使用方式
- Ubuntu on Windows10 跨平台开发环境搭建权威指南
- 如何实现CDH元数据库MySQL的主备
- 通过Java程序提交通用Mapreduce无法回收类的问题
- 如何在CDH未启用认证的情况下安装及使用Sentry
- 小白也能玩转无线安全(一)——硬件&工具入门篇
- python多线程例子
- 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 数组属性和方法
- 2.2 标识符
- 数据科学的软件工程技巧和最佳实践
- ntp 服务开机启动失败
- 4.8 this关键字
- 使用Pyppeteer进行gmail模拟登录
- 一个没法商用,但是好玩有趣的 Python 手绘图形库!
- 使用豆瓣源安装python包
- [已解决]报错:ValueError: Expected 2D array, got scalar array instead
- [已解决]报错UnicodeDecodeError
- [已解决]报错Could not install packages due to an EnvironmentError
- 用Cython加速Python代码
- [已解决]windows安装docker的问题
- 使用VBA达到vlookup效果
- Excel简单应用
- Pandas异常值处理