扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
本世纪70年代,人们曾疯魔一种被称作“生命游戏”的小游戏,这种游戏相当简单。假设有一个像棋盘一样的方格网,每个方格中放置一个生命细胞,生命细胞只有两种状态:“生”或“死”。游戏规则如下:
1. 如果一个细胞周围有3个细胞为生(一个细胞周围共有8个细胞),则该细胞为生,即该细胞若原先为死,则转为生,若原先为生,则保持不变;
2. 如果一个细胞周围有2个细胞为生,则该细胞的生死状态保持不变;
3. 在其它情况下,该细胞为死,即该细胞若原先为生,则转为死,若原先为死,则保持不变设定图像中每个像素的初始状态后依据上述的游戏规则演绎生命的变化,由于初始状态和迭代次数不同,将会得到令人叹服的优美图案。
程序的算法:
设置两个二维数组,一个用于表示当前生命细胞的状态,另一个用于判断当前的细胞的下一个状态。
这个程序还能统计当前活着的细胞的个数:
程序如下:
/*lifegame.c*/
#include <stdio.h>
#include <graphics.h>
#include <time.h>
#include <stdlib.h>
#define MAX 60
#define SIZE 5
void initG(); /*图形模式初始化*/
void closeG();/*关闭图形模式*/
void live(int col,int row);
void death(int col,int row);
void initG()
{
int gdriver=DETECT,gmode;
initgraph(&gdriver,&gmode,"d:\\tc");
cleardevice();
}
void closeG()
{
cleardevice();
settextstyle(1,0,5);
setcolor(BLUE);
outtextxy(80,50,"Programme Desiged:Y.Z.X");
outtextxy(80,160,"MAIL:yzx_xue@163.com");
outtextxy(200,330,"2006.5");
getch();
closegraph();
}
void live(int col,int row)
{
setcolor(WHITE);
setfillstyle(SOLID_FILL,WHITE);
bar(SIZE*(col+1)+1,SIZE*(row+1)+1,SIZE*(col+2)-1,SIZE*(row+2)-1);
}
void death(int col,int row)
{
setcolor(BLACK);
setfillstyle(SOLID_FILL,BLACK);
bar(SIZE*(col+1)+1,SIZE*(row+1)+1,SIZE*(col+2)-1,SIZE*(row+2)-1);
}
void table() {
int i;
setcolor(RED);
for(i=0;i<=MAX;i++)
{
line(SIZE*(i+1),SIZE,SIZE*(i+1),SIZE*(MAX+1));
line(SIZE,SIZE*(i+1),SIZE*(MAX+1),SIZE*(i+1));
}
}
void game()
{
int nrow,ncol,i,resData[MAX][MAX],ori[MAX][MAX];
int count;
char str[20];
/*if life is live color is balck*/
/*init the life*/
table();
for(nrow=0;nrow!=MAX;nrow++)
for(ncol=0;ncol!=MAX;ncol++)
{
ori[nrow][ncol]=1;
resData[nrow][ncol]=1;
}
for(i=0;i<=100;i++)
{
count=0;
for(nrow=1;nrow!=MAX;nrow++)
for(ncol=1;ncol!=MAX;ncol++)
{
if(resData[nrow][ncol]==1) live(nrow,ncol);
if(resData[nrow][ncol]==0) death(nrow,ncol);
count+=resData[nrow][ncol];
}
table();
delay(5000);
for(nrow=1;nrow<MAX;nrow++)
for(ncol=1;ncol<MAX;ncol++)
switch((ori[nrow-1][ncol-1]+ori[nrow-1][ncol]+ori[nrow-1][ncol+1]
+ori[nrow][ncol-1]+ori[nrow][ncol+1]
+ori[nrow+1][ncol-1]+ori[nrow+1][ncol]+ori[nrow+1][ncol+1]))
{
case 3: resData[nrow][ncol]=1;break;
case 2: resData[nrow][ncol]=ori[nrow][ncol]; break;
default: resData[nrow][ncol]=0;
}/*end switch*/
for(nrow=1;nrow!=MAX;nrow++)
for(ncol=1;ncol!=MAX;ncol++)
ori[nrow][ncol]=resData[nrow][ncol];
sprintf(str,"%d",count);
setcolor(RED);
rectangle(450,30,getmaxx(),200);
settextstyle(1,0,4);
outtextxy(455,40,"LIFE GAME");
outtextxy(455,100,"LIVE:");
setfillstyle(SOLID_FILL,BLACK);
bar(550,100,getmaxx()-5,140);
outtextxy(550,100,str);
} /*end time for*/
}
void main()
{
initG();
game();
getch();
closeG();
}
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者