中国MOOC_面向对象程序设计——Java语言_期末考试编程题_1细胞自动机
期末考试编程题
这是期末考试的编程题
温馨提示:
1.本次考试属于Online Judge题目,提交后由系统即时判分。
2.学生可以在考试截止时间之前提交答案,系统将取其中的最高分作为最终成绩。
题目内容:
这是细胞自动机的非图形版本。细胞自动机是指在一个二维网格内,每一个网格是一个细胞。每个细胞有活和死两种状态。
初始时刻,有些细胞是活的,有些细胞是死的。自动机的每一步,根据每个细胞周围8个格子内的其他细胞的生存情况决定这个细胞下一步是否存活。具体的规则如下:
如果该细胞现在是活的,并且周围8个格子中有2或3个活着的细胞,则继续存活;如果周围8个格子中的活着的细胞数量少于2个或多于3个,则死亡;
如果该细胞现在是死的,并且周围8个格子中正好有3个活着的细胞,则细胞复活。
位于整个网格边缘和顶角的细胞,它的周围细胞可能少于8个。即越过网格的边界不再有细胞。
每个细胞的生死变化,都不会影响当前这一步周围的细胞,只会在下一步表现出来。
提示:课程中的代码与上一句描述不同。
输入格式:
首先输入两个正整数,范围为[3,102],依次表示网格的宽度和高度。
然后输入多组正整数,依次表示一个活着的细胞的网格位置,每组数字中,第一个表示行号,第二个表示列号,均从0开始编号。
最后,以“-1 -1”表示不再有活着的细胞。-1 -1不是有效的位置。
然后,以一个正整数,范围为[1,10000],表示要求细胞自动机执行的步数。
输出格式:
输出一个正整数,表示执行完毕后,剩下的活着的细胞的数量。
输入样例:
3 3
1 1 1 2 0 1 2 1
-1 -1
1
输出样例:
7
import java.util.Scanner;
public class CellMachine {
static Scanner in = new Scanner(System.in);
static int width = 0;// 宽度
static int height = 0;// 高度
static int[][] field_old;// 旧的网格
static int[][] field_new;// 新的网格
static int times;// 步数
public static void main(String[] args) {
// 首先输入两个正整数,范围为[3,102],依次表示网格的宽度和高度。
width = in.nextInt();
height = in.nextInt();
// 初始化数组
initial();
// 然后,以一个正整数,范围为[1,10000],表示要求细胞自动机执行的步数。
times = in.nextInt();
// 细胞自动机执行
run(times);
System.out.println(count(field_old));// 输出一个正整数,表示执行完毕后,剩下的活着的细胞的数量。
}
// 初始化数组
public static void initial() {
field_old = new int[height][width];
field_new = new int[height][width];
for (int i = 0; i < field_old.length; i++) {
for (int j = 0; j < field_old[i].length; j++) {
field_old[i][j] = 0;
field_new[i][j] = 0;
}
}
// 然后输入多组正整数,依次表示一个活着的细胞的网格位置,每组数字中,第一个表示行号,第二个表示列号,均从0开始编号。
while (true) {
int i = in.nextInt();
int j = in.nextInt();
if (i == -1 && j == -1) {
break;// 最后,以“-1 -1”表示不再有活着的细胞。-1 -1不是有效的位置。
}
field_old[i][j] = 1;
field_new[i][j] = 1;
}
}
// 细胞自动机执行
public static void run(int times) {
int number = 0;
for (int i = 0; i < times; i++) {
for (int j = 0; j < field_old.length; j++) {
for (int k = 0; k < field_old[j].length; k++) {
number = getNeighbour(j, k);// 计算周围活着的细胞
if (field_old[j][k] == 1 && (number == 2 || number == 3)) {
field_new[j][k] = 1;
} else {
field_new[j][k] = 0;
}
if (field_old[j][k] == 0 && number == 3) {
field_new[j][k] = 1;
}
}
}
for (int j = 0; j < field_new.length; j++) {
for (int k = 0; k < field_new[j].length; k++) {
field_old[j][k] = field_new[j][k];// 把新的复制到旧的
}
}
}
}
// 计算周围活着的细胞
public static int getNeighbour(int i, int j) {
int number = 0;
if (i == 0 && j == 0) {// 左上角
number = field_old[i][j + 1] + field_old[i + 1][j + 1] + field_old[i + 1][j];
} else if (i == 0 && j == width - 1) {// 右上角
number = field_old[i][j - 1] + field_old[i + 1][j - 1] + field_old[i + 1][j];
} else if (i == height - 1 && j == 0) {// 左下角
number = field_old[i - 1][j] + field_old[i - 1][j + 1] + field_old[i][j + 1];
} else if (i == height - 1 && j == width - 1) {// 右下角
number = field_old[i - 1][j] + field_old[i - 1][j - 1] + field_old[i][j - 1];
} else if (i == 0) {// 首行其他
number = field_old[i][j - 1] + field_old[i + 1][j - 1] + field_old[i + 1][j] + field_old[i + 1][j + 1]
+ field_old[i][j + 1];
} else if (i == height - 1) {// 末行其他
number = field_old[i][j - 1] + field_old[i - 1][j - 1] + field_old[i - 1][j] + field_old[i - 1][j + 1]
+ field_old[i][j + 1];
} else if (j == 0) {// 最左其他
number = field_old[i - 1][j] + field_old[i - 1][j + 1] + field_old[i][j + 1] + field_old[i + 1][j + 1]
+ field_old[i + 1][j];
} else if (j == width - 1) {// 最右其他
number = field_old[i - 1][j] + field_old[i - 1][j - 1] + field_old[i][j - 1] + field_old[i + 1][j - 1]
+ field_old[i + 1][j];
} else {// 其他
number = field_old[i - 1][j - 1] + field_old[i - 1][j] + field_old[i - 1][j + 1] + field_old[i][j + 1]
+ field_old[i + 1][j + 1] + field_old[i + 1][j] + field_old[i + 1][j - 1] + field_old[i][j - 1];
}
return number;
}
// 剩下的活着的细胞的数量
public static int count(int[][] field) {
int number = 0;
for (int i = 0; i < field.length; i++) {
for (int j = 0; j < field[i].length; j++) {
if (field[i][j] == 1) {
number++;
}
}
}
return number;
}
}
中国MOOC_面向对象程序设计——Java语言_期末考试编程题_1细胞自动机的更多相关文章
- 中国MOOC_面向对象程序设计——Java语言_第3周 对象容器_1查找里程
第3周编程题 查看帮助 返回 第3周编程题.注意程序(包括注释)中不能出现汉字. 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨提示: 1.本次作业属于Online Judge题目,提交后 ...
- 中国MOOC_面向对象程序设计——Java语言_第2周 对象交互_秒计时的数字时钟
第2周编程题 查看帮助 返回 第2周编程题,在课程所给的时钟程序的基础上修改 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨提示: 1.本次作业属于Online Judge题目,提交后由系 ...
- 中国MOOC_面向对象程序设计——Java语言_第1周 类与对象
第1周编程题 查看帮助 返回 我们在题目说明中给出了一部分代码,你需要在这部分代码的基础上,按照题目说明编写代码,然后将两部分代码一起提交. 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨 ...
- 中国MOOC_面向对象程序设计——Java语言_第2周 对象交互_1有秒计时的数字时钟
第2周编程题 查看帮助 返回 第2周编程题,在课程所给的时钟程序的基础上修改 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨提示: 1.本次作业属于Online Judge题目,提交后由系 ...
- 中国MOOC_面向对象程序设计——Java语言_第1周 类与对象_1分数
第1周编程题 查看帮助 返回 我们在题目说明中给出了一部分代码,你需要在这部分代码的基础上,按照题目说明编写代码,然后将两部分代码一起提交. 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨 ...
- 中国MOOC_面向对象程序设计——Java语言_第4章 继承与多态_第4周编程题_将MP3媒体类型存放进Database
本周我们介绍了以继承方式实现的媒体资料库,在课程代码实现的基础上,请实现一个表达MP3的媒体类型,能和CD.DVD一样存放进这个Database.请提交这个MP3类的代码.如果你认为为了能存放MP3, ...
- 面向对象程序设计--Java语言第三周编程题:查找里程
查找里程 题目内容: 下图为国内主要城市之间的公路里程: 你的程序要读入这样的一张表,然后,根据输入的两个城市的名称,给出这两个城市之间的里程. 注意:任何两个城市之间的里程都已经给出,不需要计算经第 ...
- 网易云课堂_程序设计入门-C语言_期末考试编程题
1 字数统计(10分) 题目内容: 你的程序要读入一篇英文文章,然后统计其中的单词数来输出.需要统计的数据为: 总的单词数量: 含有1个字母到10个字母的单词的数量. 单词和单词的间隔是由以下标点符号 ...
- 中国MOOC_零基础学Java语言_期末考试的编程题_1二进制的前导的零
期末考试的编程题 返回 这是期末考试的编程题,在60分钟内,你可以多次提交,直到正确为止. 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止 ...
随机推荐
- Nginx 故障实例
linux vi 操作提示 Found a swap file by the name "/usr/local/nginx/conf/.nginx.conf.swp" 解决方法: ...
- Jmeter分布式测试dubbo接口1
最近工作中接到一个需求,需要对一个Dubbo接口进行压力测试,测试其性能,之前一直使用jmeter做压力测试,在踏了好多坑之后,决定把这些记录下来,顺便也希望能帮助到大家. 开始测试之前,我们需要先知 ...
- ui自动化之selenium操作(四)简单元素操作
1. clear() clear()方法用于清除文本输入框内的内容:一般输入框中都有默认文字,如果不清空有可能会导致字符拼接: browser.find_element(By.ID,"use ...
- Windows如何下载nginx软件包到linux系统虚拟机上
1.打开浏览器,输入“nginx下载官网” 2.点击nginx:download 3.找到你想下载的nginx软件包 4.点击你所需要的版本之后(我点击的是nginx-1.12.2版本,根据自己的需要 ...
- Maven工程构建
Maven 相关术语: 本地资源库:用来存储项目的依赖库,默认的文件夹是 “.m2” 目录 中央存储库: 用来下载所有项目的依赖库的默认位置 Maven pom.xml: 项目对象模型(Project ...
- HYSBZ-4033-树上染色(树上DP)
链接: https://vjudge.net/problem/HYSBZ-4033 题意: 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并 ...
- 【ZJOJ1321】灯
题目 贝希和她的闺密们在她们的牛棚中玩游戏.但是天不从人愿,突然,牛棚的电源跳闸了,所有的灯都被关闭了.贝希是一个很胆小的女生,在伸手不见拇指的无尽的黑暗中,她感到惊恐,痛苦与绝望.她希望您能够帮帮她 ...
- fabric报错:Fatal error: run() received nonzero return code 1 while executing!
今天在使用fabric远程安装rpm时,一直报:Fatal error: run() received nonzero return code 1 while executing! 这看起来也是没笔病 ...
- 利用aspose-words直接将Word转化为图片
之前遇到一个需求,需要在word文档中加入一些文字,并转化为图片.之前也试过几种方案,但是发现效果还不是很理想,且中间需要经过一次转化为pdf的过程,最近找到了最理想的方式,即利用aspose-wor ...
- 【Leetcode】判断平面中1个点是否落在三角形内
参考资料: 题目: https://blog.csdn.net/dongtinghong/article/details/78657403 符号重载: https://blog.csdn.net/cd ...