Удаление всех строк, содержащих минимальный элемент матрицы - C (СИ)
Формулировка задачи:
Доброго времени суток!
Написал программу на Си удаления всех строк, содержащих минимальный элемент матрицы,
но она падает, если в массиве встречается 0.
Не могу понять в чём дело. Помогите, пожалуйста найти ошибку
#include <stdio.h>
#define N 7
int main()
{
int a[N][N], n, i, j, k, m, min, removed;
while (1)
{
printf("Введите n (1 - %d. Завершить - 0): ", N);
scanf_s("%d", &n);
if (n == 0) break;
if (n < 1 || n > N)
{
printf("Недопустимое значение n\n");
continue;
}
for (i = 0; i < n; i++)
for (j = 0; j < n; j++)
scanf_s("%d", &a[i][j]);
printf("Исходная матрица:\n");
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++) printf("%d ", a[i][j]);
printf("\n");
}
min = a[0][0];
for (i = 0; i < n; i++)
for (j = 0; j < n; j++)
if (a[i][j] < min) min = a[i][j];
removed = 0;
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++)
{
if (a[i][j] == min)
{
for (m = i; m < n - removed; m++)
for (k = 0; k < n; k++) a[m][k] = (m < n - removed - 1 ? a[m + 1][k] : 0);
removed++;
i--;
break;
}
}
}
printf("Результат:\n");
if (n - removed == 0) printf("Все строки были удалены, так как они содержали минимальный элемент\n");
else
for (i = 0; i < n - removed; i++)
{
for (j = 0; j < n; j++) printf("%d ", a[i][j]);
printf("\n");
}
}
return 0;
}Решение задачи: «Удаление всех строк, содержащих минимальный элемент матрицы»
textual
Листинг программы
for (k = 0; k < n; k++) a[m][k] = (m < n - removed - 1 ? a[m + 1][k] : 0);
Объяснение кода листинга программы
В данном коде выполняется итерация по всем элементам матрицы a. Значение каждой ячейки a[m][k] присваивается значению следующей ячейки a[m + 1][k], если она существует, иначе 0.
В данном коде отсутствует проверка выхода за границы матрицы, что может привести к ошибкам при выполнении кода.