用c语言演绎“生命游戏”

本文通过C语言结合图形库实现了一个简单的“生命游戏”模拟程序。该程序在一个二维网格中模拟细胞的生存状态变化,并通过迭代更新网格来展示细胞群体随时间演化的规律。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <graphics.h>

  main(){

  int orgData[100][100],resData[100][100];/*分别记录每次迭代的初始和结果状态*/

  int nCount,nRows,nCols,i,j,times; /*times记录迭代次数*/

  int GraphDriver=DETECT,GraphMode;

  for (i=0;i<100;i++) /*初始化数据,令每一个细胞为生*/

  for (j=0;j<100;j++) orgData[i][j]=1;

  initgraph(&GraphDriver,&GraphMode,′′′′); /*初始化屏幕显示*/

  setcolor(WHITE);

  rectangle(270,190,370,290); /*作显示边框*/

  for (times=1;times<200;times++){

  for (nRows=1;nRows<99;nRows++) {

  for (nCols=1;nCols<99;nCols++){

  /*计算每一个细胞周围的活的细胞数*/

  nCount=orgData[nRows-1][nCols-1]+orgData[nRows-1][nCols]

  +orgData[nRows-1][nCols+1]+orgData[nRows][nCols-1]

  +orgData[nRows][nCols+1]+orgData[nRows+1][nCols-1]

  +orgData[nRows+1][nCols]+orgData[nRows+1][nCols+1];

  switch(nCount){

  /*周围有3个活细胞,该细胞为生,在屏幕上用黑色像素表示*/

  case 3: putpixel(nCols+210,120+nRows,BLACK);

  resData[nRows][nCols]=1;break;

  /*周围有2个活细胞,该细胞不变,在屏幕显示也不变*/

  case 2: resData[nRows][nCols]=orgData[nRows][nCols];

  break;

  /*其它情况下,细胞为死,在屏幕上用白色像素表示*/

  default:resData[nRows][nCols]=0;

  putpixel(nCols+210,120+nRows,WHITE);

  }

  }

  }

  for (i=1;i<99;i++)

  for (j=1;j<99;j++) orgData[i][j]=resData[i][j];

  getch();

  }

  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值