生命游戏

在一个细胞群中,包含8个方向的邻居,对于一个细胞有如下的规则:

1.如果一个细胞的邻居少于1,则下一时刻他将死亡

2.如果一个细胞的邻居多余4个,则下一时刻他将死亡

3.如果一个细胞的邻居为2或者3,下一时刻他将存活

4.若一个位置没有细胞,而他又3个邻居,则下一时刻将会产生一个新细胞

#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>

#define MAXROW 10
#define MAXCOL 25
#define DEAD 0
#define ALIVE 1

int map[MAXROW][MAXCOL],newmap[MAXROW][MAXCOL];
int life = 0;

void init();
int neighbors(int,int);
void outputMap();
void copyMap();

int main()
{
    int row,col;
    char ans;
    init();
    while(1)
    {
        outputMap();
        //update the situation 
        for(row = 0; row < MAXROW; row++)
        {
            for(col = 0; col < MAXCOL; col++)
            {
                switch(neighbors(row,col))
                {
                    case 0:
                    case 1:
                    case 4:
                    case 5:
                    case 6:
                    case 7:
                    case 8:
                        newmap[row][col] = DEAD;
                        break;
                    case 2:
                        newmap[row][col] = map[row][col];
                        break;
                    case 3:
                        newmap[row][col] = ALIVE;
                        break;
                }
            }
        }
        copyMap();
        printf("Continue next Generation?");
        getchar();
        ans = toupper(getchar());
        if(ans != 'Y')
            break;
    }
    return 0;
}

/*
input init data
*/
void init()
{
    int row,col;

    for(row = 0; row < MAXROW; row++)
        for(col = 0; col < MAXCOL; col++)
            map[row][col] = DEAD;

    puts("Game of life Program");
    puts("Enterx,y where x,y is living cell");
    printf("0 <= x <= %d, 0 <= y <= %d\n",MAXROW - 1, MAXCOL -1 );
    puts("Terminate with x,y = -1,-1");

    while(1)
    {
        scanf("%d %d",&row, &col);
        if(0 <= row && row <= MAXROW - 1 && 0 <= col && col <= MAXCOL - 1)
            map[row][col] = ALIVE;
        else if(row == -1 || col == -1)
            break;
        else
            printf("x,y exceeds map ranage!\n");
    }
}

/*
return the neighbors number,which Alive
*/
int neighbors(int row, int col)
{
    int count = 0, c, r;
    for(r = row - 1; r <= row + 1; r++)
        for(c = col - 1;c <= col +1; c++)
        {
            if(r < 0 || r >= MAXROW || c < 0 || c >= MAXCOL)
                continue;
            if(map[r][c] == ALIVE)
                count++;
        }
    if(map[row][col] == ALIVE)
        count--;
    return count;
}

void outputMap()
{
    int row, col;
    printf("\nGame of life cell %d status\n",life++);
    for(row = 0; row < MAXROW; row++)
    {
        printf("\n");
        for(col = 0; col < MAXCOL; col++)
            if(map[row][col] == ALIVE)
                putchar('#');
            else
                putchar('-');
    }
}

void copyMap()
{
    int row, col;
    for(row = 0; row < MAXROW; row++)
        for(col  = 0; col < MAXCOL; col++)
            map[row][col] = newmap[row][col];
}
在这个过程中有一个有趣的现象,在初始化到达一定的程度时,经过若干次操作,细胞群的会趋于稳定,在两个状态之间无限切换,显而易见的是,这最终的两个状态与生存规则有相应的关联(一个平行或竖直的三连细胞组的生存变化就是无限的横竖切换)。比如下面这个初始细胞群。

-------------------------
-------------------------
-------------------------
---###-------------------
---##--------------------
-----#-------------------
---#--#------------------
-------------------------
-------------------------
-------------------------
第十一次:
-------------------------
------------###----------
-------------------------
----------#-----#--------
----------#-----#--------
----------#-----#--------
-------------------------
------------###----------
-------------------------
-------------------------
第十二次:
-------------#-----------
-------------#-----------
-------------#-----------
-------------------------
---------###---###-------
-------------------------
-------------#-----------
-------------#-----------
-------------#-----------
-------------------------
第十三次:
-------------------------
------------###----------
-------------------------
----------#-----#--------
----------#-----#--------
----------#-----#--------
-------------------------
------------###----------
-------------------------
-------------------------



1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值