当前位置: 首页 > news >正文

python实现生命游戏

“生命游戏”(Conway’s Game of Life)是由数学家约翰·康威提出的一种零玩家游戏。它是一个细胞自动机,由一组简单的规则决定每个细胞的状态。以下是用Python实现“生命游戏”的代码示例:

Python代码实现

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animationdef initialize_grid(size):"""初始化游戏的网格,随机设置细胞状态(0为死,1为生)"""return np.random.choice([0, 1], size*size, p=[0.8, 0.2]).reshape(size, size)def update_grid(grid):"""根据生命游戏规则更新网格"""# 创建一个副本,用于计算邻居new_grid = grid.copy()size = grid.shape[0]# 遍历每个细胞for i in range(size):for j in range(size):# 计算该细胞周围的活细胞数total = int((grid[i, (j-1)%size] + grid[i, (j+1)%size] +grid[(i-1)%size, j] + grid[(i+1)%size, j] +grid[(i-1)%size, (j-1)%size] + grid[(i-1)%size, (j+1)%size] +grid[(i+1)%size, (j-1)%size] + grid[(i+1)%size, (j+1)%size]))# 生命游戏规则if grid[i, j] == 1:if (total < 2) or (total > 3):new_grid[i, j] = 0  # 死亡else:if total == 3:new_grid[i, j] = 1  # 诞生return new_griddef animate(frame, grid, plot):"""更新动画帧"""grid[:] = update_grid(grid)plot.set_data(grid)return plot,def run_game_of_life(size=50, interval=200):"""运行生命游戏"""grid = initialize_grid(size)fig, ax = plt.subplots()plot = ax.imshow(grid, cmap='binary')ani = animation.FuncAnimation(fig, animate, fargs=(grid, plot), frames=10, interval=interval, save_count=50)plt.show()# 运行游戏
run_game_of_life(size=50, interval=200)

代码说明

  1. initialize_grid(size): 生成一个随机的初始网格,网格中的每个细胞随机设置为活(1)或死(0)。

  2. update_grid(grid): 根据生命游戏的规则更新网格状态:

    • 规则1: 任何活细胞,如果有两个或三个邻居仍然存活,否则它将死亡。
    • 规则2: 任何死细胞,如果有恰好三个邻居活着,则该细胞诞生。
  3. animate(frame, grid, plot): 这个函数是用来逐帧更新动画的。

  4. run_game_of_life(size=50, interval=200): 这是运行游戏的主要函数,它设置了网格大小和动画帧之间的间隔时间。最终会显示一个动画,演示生命游戏的过程。

运行代码

当你运行run_game_of_life()函数时,将会显示一个动态的图像,展示细胞的生与死的演化过程。size参数决定网格的大小,interval参数控制动画的速度。

http://www.lryc.cn/news/425563.html

相关文章:

  • 基于vue框架的CIA报价平台的设计与实现1xv02(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
  • 【Kubernetes】k8s集群Pod控制器
  • 什么是NLP实体识别?
  • 掌握Jenkins自动化部署:从代码提交到自动上线的全流程揭秘
  • 糟糕界面集锦-控件篇09
  • 喵喵蓝牙热敏打印机(下)
  • 软件测试第1章 软件测试是什么
  • 【技术分享】 hysteria2从服务端到客户端部署教程
  • C++入门基础知识16
  • 浏览器调试工具-Chrome Dev Tools
  • 基于车联网大数据平台的用户驾驶习惯行为画像分析
  • Ubuntu24.04搭建maxkb开发环境
  • C++ 指针和引用的区别
  • python绘制蕨菜叶分形
  • 1分钟了解pandas
  • django-celery应用-定时执行测试cases
  • 【C++深度探索】unordered_set、unordered_map封装
  • CSS——字体背景(Font Background)
  • 秋招突击——8/15——知识补充——Socket通信
  • Qt第十四章 模型视图
  • 硬件工程师必须掌握的MOS管详细知识
  • 希尔排序,详细解析(附图解)
  • 【C语言篇】编译和链接以及预处理介绍(下篇)
  • 利用Llama2 7b自己实现一套离线AI
  • Ciallo~(∠・ω・ )⌒☆第十七篇 Ubuntu基础使用 其一
  • Linux-零拷贝技术
  • 小区团购管理
  • 图像文本擦除无痕迹!复旦提出EAFormer:最新场景文本分割新SOTA!(ECCV`24)
  • Codeforces Round 966 (Div. 3)(A,B,C,D,E,F)
  • 【代码随想录算法训练营第42期 第六天 | LeetCode242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和】