为什么第三板有一个错误
why there is a mistake in the third board?
我假设每个人都听说过游戏,但是如果没有,则是一个链接:https://bitstorm.org/gameoflife/
我正在尝试在不使用结构,类等的情况下在C 中实现它。
到目前为止,我已经做到了:
#define N 10
#define M 10
#include <iostream>
bool** createGrid(int n, int m)
{
bool** grid = new bool*[n];
for (int i = 0; i < n; i++)
grid[i] = new bool[m];
return grid;
}
void displayGrid(bool** grid, int n, int m)
{
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (grid[i][j] == 1)
std::cout << 'X';
else
std::cout << '.';
}
std::cout << std::endl;
}
std::cout << "##########n";
}
void releaseGrid(bool** grid, int n)
{
for (int i = 0; i < n; i++)
delete[] grid[i];
delete[] grid;
}
int countAliveNeighbours(bool** grid, int k, int l)
{
int aliveNeighbours = 0;
for (int i = -1; i <= 1; i++)
for (int j = -1; j <= 1; j++)
aliveNeighbours += grid[k + i][l + j];
// The cell needs to be subtracted from it's neighbours as it was counted before
aliveNeighbours -= grid[k][l];
return aliveNeighbours;
}
bool** nextGeneration(bool** grid, int n, int m)
{
bool** next = createGrid(n, m);
// Loop through every cell
for (int k = 1; k < n - 1; k++) {
for (int l = 1; l < m - 1; l++) {
// finding count of neighbours that are alive
int aliveNeighbours = countAliveNeighbours(grid, k, l);
// Implementing the Rules of Life
// Cell is lonely and dies
if ((grid[k][l] == 1) && (aliveNeighbours < 2))
next[k][l] = 0;
// Cell dies due to over population
else if ((grid[k][l] == 1) && (aliveNeighbours > 3))
next[k][l] = 0;
// A new cell is born
else if ((grid[k][l] == 0) && (aliveNeighbours == 3))
next[k][l] = 1;
// Remains the same
else
next[k][l] = grid[k][l];
}
}
return next;
}
bool checksTwoGridsForDifferences(bool** prevGrid, bool** nextGrid, int n, int m)
{
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (prevGrid[i][j] != nextGrid[i][j]) {
return true;
}
}
}
return false;
}
void fillGrid(bool** grid, int n, int m)
{
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
grid[i][j] = 0;
}
}
grid[1][3] = 1;
grid[1][4] = 1;
grid[2][4] = 1;
grid[5][3] = 1;
grid[5][4] = 1;
grid[6][2] = 1;
grid[6][3] = 1;
grid[7][5] = 1;
grid[8][4] = 1;
}
int main()
{
bool** prevGrid = createGrid(N, M); // create starting grid
fillGrid(prevGrid, N, M); // fill starting grid
std::cout << "Starting grid:n";
displayGrid(prevGrid, N, M); // display starting grid
bool** nextGrid = nextGeneration(prevGrid, N, M); //generate next grid
while (checksTwoGridsForDifferences(prevGrid, nextGrid, N, M)) {
displayGrid(nextGrid, N, M);
releaseGrid(prevGrid, N);
prevGrid = nextGrid;
nextGrid = nextGeneration(prevGrid, N, M);
}
releaseGrid(nextGrid, N);
releaseGrid(prevGrid, N);
return 0;
}
但是我被卡住了,因为第三个网格不正确(它错误地擦除了两个X(,我想知道为什么?谁能告诉我错误?
它显示:
..........
..........
...XX.....
..........
...X......
..X.X.....
..........
..XXX.....
..........
..........
而不是:
..........
...XX.....
...XX.....
..........
...X......
..X.X.....
..........
..XXX.....
..........
..........
问题是您没有填充下一代网格的边缘。nextGeneration
中的评论// Loop through every cell
是不正确的,因为您跳过网格的边缘。
您需要在countAliveNeighbours
功能上更加努力地工作,以免跨越网格的边缘,然后更改nextGeneration
函数,以便您确实在每个单元格中确实循环。或者您可以永久关闭网格的边缘。
我使用调试器在大约两分钟内发现了这个问题。我看不到代码来看到它。您确实应该教自己如何使用调试器。这是您作为程序员的生产力最大的一步。
提出的问题顺便说一句,足够的信息可以轻松解决问题。
相关文章:
- VSCode-有一个红色下划线,但程序构建和运行正确,并且出现配音错误
- 我在 .h 中有一个枚举类,并且在.cpp错误中有一个运算符重载:与"运算符<<不匹配
- 我有一个线程 1:EXC_BAD_ACCESS(代码 = 1,地址 = 0x8)错误.我认为这是由于内存管理不好.我可以
- 处理程序的模块列表中有一个错误的模块"WebSocketModule"
- 我如何在一个 if 语句中声明所有数字我尝试通过其他方式声明所有数字,如果一个接一个,但似乎代码有逻辑错误
- 编译器错误:函数调用在常量表达式中必须有一个常量值
- 为什么第三板有一个错误
- 我在代码中有一个错误,错误是:(智能感知:不允许抽象类类型"HourlyWorker"的对象:)
- 带有显式构造函数的智能指针使我有一个错误
- 它不是编译.我正在调用一个通过引用调用的函数,但有一个错误,无法将双*转换为双倍
- 删除指向排序的字符串阵列的指针会在运行后会有一个错误
- 这里有一个错误:"string subscript is out of range"
- Microsoft C++编译器有一个错误
- 我有一个错误LNK2019:未解决的外部符号错误(要查看少量代码)
- 我的代码中有一个错误,可能是语法或我找不到的 if 语句。编程新手
- 我的返回语句有一个错误,我不知道要修复
- 有一个错误与我的c++类项目
- "cannot create .moc/main.moc "有一个错误,当我编译Qt5.7的mysql驱动程序时
- 是否空指针分配分区有一个错误
- 嵌套向量不遵循提升规则.解决方案有一个错误