【问题标题】:Class that is supposed to count neighboring cells in a 2D array doesn't count properly in C#应该计算二维数组中相邻单元格的类在 C# 中计算不正确
【发布时间】:2021-01-19 14:23:41
【问题描述】:

我用 C# 编写了一个类,用于计算二维数组中的相邻活细胞。假设我有一个这样的数组

int[,] array = new int[8, 8]
{
    {3, 3, 3, 3, 3, 3, 3, 3},
    {3, 0, 0, 0, 0, 0, 0, 3},
    {3, 0, 0, 0, 1, 0, 0, 3},
    {3, 0, 1, 0, 0, 1, 0, 3},
    {3, 0, 1, 0, 0, 1, 0, 3},
    {3, 0, 0, 1, 0, 0, 0, 3},
    {3, 0, 0, 0, 0, 0, 0, 3},
    {3, 3, 3, 3, 3, 3, 3, 3}
};

在这个数组中,0 是死细胞,1 是活细胞,3 是幽灵细胞。我的班级应该计算并返回01 的所有相邻活细胞。对于这个数组,如果我要打印它应该返回的邻居

0 0 0 0 0 0 0 0
0 0 0 1 1 1 0 0
0 1 1 2 1 2 1 0
0 2 1 3 3 2 2 0
0 2 2 3 3 1 2 0
0 1 2 1 2 1 1 0
0 0 1 1 1 0 0 0
0 0 0 0 0 0 0 0

相反,它返回

0 0 0 0 0 0 0 0
0 0 0 1 1 1 0 0
0 1 1 1 1 1 1 0
0 1 1 1 1 1 1 0
0 1 1 1 1 1 1 0
0 1 1 1 1 1 1 0
0 0 1 1 1 0 0 0
0 0 0 0 0 0 0 0

对于任何给定的活细胞,它似乎只将邻居计数到1。这是我的课用来计算周围的活细胞

public static int NeighbourCount(int[,] array, int x, int y)
{
    int neighours = 0;

    if (array[x, y] != 3)
    {
             if (array[x + 1, y    ] == 1) { neighours++; }
        else if (array[x + 1, y - 1] == 1) { neighours++; }
        else if (array[x    , y - 1] == 1) { neighours++; }
        else if (array[x - 1, y - 1] == 1) { neighours++; }
        else if (array[x - 1, y    ] == 1) { neighours++; }
        else if (array[x - 1, y + 1] == 1) { neighours++; }
        else if (array[x    , y + 1] == 1) { neighours++; }
        else if (array[x + 1, y + 1] == 1) { neighours++; }
    }

    return neighours;
}

我不明白为什么这只返回0's 和1's。知道是什么导致了这个问题吗?问题可能是我如何打印课程返回吗?我是这样打印的

for (int i = 0; i < array.GetLength(0); i++)
{
    for (int j = 0; j < array.GetLength(0); j++)
    {
        Console.Write(NeighbourCount(array, i, j) + " ");
    }
    Console.WriteLine(string.Join(" ", ascii));
    ascii.Clear();
}

任何关于什么问题的解决方案或想法将不胜感激!谢谢。

【问题讨论】:

  • 变量ascii是如何定义填充值的?

标签: c# arrays 2d counting


【解决方案1】:

您应该检查if 语句中的所有条件,但在您的代码中,条件会一直检查到值为true 的第一个条件。只需删除所有 else 语句即可。

public static int NeighbourCount(int[,] array, int x, int y)
{
    int neighours = 0;

    if (array[x, y] != 3)
    {
        if (array[x + 1, y    ] == 1) { neighours++; }
        if (array[x + 1, y - 1] == 1) { neighours++; }
        if (array[x    , y - 1] == 1) { neighours++; }
        if (array[x - 1, y - 1] == 1) { neighours++; }
        if (array[x - 1, y    ] == 1) { neighours++; }
        if (array[x - 1, y + 1] == 1) { neighours++; }
        if (array[x    , y + 1] == 1) { neighours++; }
        if (array[x + 1, y + 1] == 1) { neighours++; }
    }

    return neighours;
}

查看:https://dotnetfiddle.net/UQV4Up

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-09-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-04-22
    • 1970-01-01
    • 2020-07-22
    • 1970-01-01
    相关资源
    最近更新 更多