Подсчет количества появлений числа в двумерном массиве C - PullRequest
0 голосов
/ 17 сентября 2018

Я пытаюсь подсчитать, сколько раз число появляется в двумерном массиве, но когда я пытаюсь распечатать значения, оно начинает давать неправильные числа после первого элемента. Я пытаюсь выяснить это для проекта судоку, который у меня есть, но я публикую другой исходный код, чтобы понять, почему это происходит.

#include <stdio.h>

int main() {
    int i, j, k;
    char check[10];
    char puzzle[6][10] = {
        { 1, 1, 3, 4, 4, 4, 5, 9, 2, 7 },
        { 9, 9, 8, 8, 8, 8, 8, 6, 9, 5 },
        { 1, 1, 3, 4, 4, 4, 5, 9, 2, 7 },
        { 9, 9, 8, 8, 8, 8, 8, 6, 9, 5 },
        { 1, 1, 3, 4, 4, 4, 5, 9, 2, 7 },
        { 9, 9, 8, 8, 8, 8, 8, 6, 9, 5 }
    };

    for (i = 0; i < 6; i++) {
        for (j = 0; j < 10; j++) {
            check[puzzle[i][j]]++;
        }
    }
    for (k = 1; k < 10; k++) {
        printf("check[%d] = %d\n", k, check[k]);
    }
    return 0;
}

ВЫВОД:

check[1] = 6
check[2] = -101
check[3] = -6
check[4] = -56
check[5] = 101
check[6] = 2
check[7] = -126
check[8] = 15
check[9] = 12
Program ended with exit code: 0

1 Ответ

0 голосов
/ 18 сентября 2018

Я пытаюсь подсчитать, сколько раз число появляется в 2D массив, но когда я пытаюсь напечатать значения, он начинает давать мне неправильно цифры после первого элемента.

Значения в массиве check, которые вы увеличиваете, отличны от нуля, поскольку массив никогда не инициализируется.

Эта строка:

char check[10];

Это должно быть так:

char check[10] = {0};
...