0

我正在基于 Conway 的 Game of Life 在 Ubuntu 中使用 GCC 创建一个简单的 C 应用程序。我基本上拥有我需要的所有代码,但是我在代码的一个小方面遇到了问题。

我的 C 源文件:

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

#define HEIGHT 32
#define WIDTH 32
#define COMPASS 8
#define SPACE '.'

unsigned long mask = 0x80000000;
unsigned long row[WIDTH] = { 0 };
unsigned long copy[WIDTH] = { 0 };

int northWest(int rowNum) {
    copy[rowNum - 1] = row[rowNum - 1] >>= 1;
    return copy[rowNum - 1] & row[rowNum];
}

int north(int rowNum) {
    copy[rowNum - 1] = row[rowNum - 1];
    return copy[rowNum - 1] & row[rowNum];
}

int northEast(int rowNum) {
    copy[rowNum - 1] = row[rowNum - 1] <<= 1;
    return copy[rowNum - 1] & row[rowNum];
}

int west(int rowNum) {
    copy[rowNum] = row[rowNum] >>= 1;
    return copy[rowNum] & row[rowNum];
}

int east(int rowNum) {
    copy[rowNum] = row[rowNum] <<= 1;
    return copy[rowNum] & row[rowNum];
}

int southWest(int rowNum) {
    copy[rowNum + 1] = row[rowNum + 1] >>= 1;
    return copy[rowNum + 1] & row[rowNum];
}

int south(int rowNum) {
    copy[rowNum + 1] = row[rowNum];
    return copy[rowNum + 1] & row[rowNum];
}

int southEast(int rowNum) {
    copy[rowNum + 1] = row[rowNum + 1] <<= 1;
    return copy[rowNum + 1] & row[rowNum];
}

void clearRows(unsigned long row[]) {
    int i;
    system("clear");
    for (i = 0; i < HEIGHT; ++i) {
        row[i] = 0;
    }
}

void displayBinary(unsigned long x) {
    int bit;
    /*int mask;*/
    for (bit = 0; bit < HEIGHT; ++bit)
    {
        mask = 1 << bit;
        printf("%c", (x & mask) ? 'X' : SPACE);
    }
    printf("\n");
}

int main(void) {
    int i, j, alive;
    char ch;
    unsigned long init32;
    srand(time(NULL));

    for (i = 0; i < HEIGHT; ++i) {
        init32 = ((double)rand() / RAND_MAX) * 0xFFFFFFFF;
        row[i] = init32;
        displayBinary(row[i]);
    }

    do {
        system("clear");
        for (i = 0; i < WIDTH; ++i) {
            unsigned long neighbours[COMPASS] = {
                north(i),
                south(i),
                west(i),
                east(i),
                northEast(i),
                northWest(i),
                southEast(i),
                southWest(i)
            };

            for (j = 0; j < COMPASS; ++j) {
                alive += ((mask & neighbours[j]) ? 1 : 0);
            }

            displayBinary(row[i]);
        }
    } while ((ch = getchar()) != 'n');

    return EXIT_SUCCESS;
}

当应用程序第一次启动时,输出是我所期望的(随机 'X' 和 '.' 字符的 32x32 网格),但是对于之后的每次迭代,没有任何变化。我希望每个循环根据我拥有的方法(north()、west() 等)重新计算邻居并打印新的“X”和“。” 32x32 网格上的值。

任何人都可以就如何将新值放入要在屏幕上打印的数组提供某种帮助吗?顺便说一句,我是 C 编程新手。谢谢。

4

1 回答 1

2

我没有看到您在代码中的任何位置更新行数组。你不应该在你的 do while 循环中更新它吗?

好的,我在下面复制的函数中看到了,您也在使用 row >>= 1 来更改行。但是由于您使用的是按值传递而不是按引用传递,因此原始行值保持不变。

int northWest(unsigned long row, int rowNum) {
    copy[rowNum - 1] = row >>= 1;
    return copy[rowNum - 1];
}

您可以使用按值传递来解决此问题。或由于您的行数组是全局的,您可以使用您传递的 rowNum (索引)直接在这些函数中更改它。

于 2014-02-05T20:36:15.267 回答