#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 100
// Прототипы функций
void read_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols);
void print_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols);
int **allocate_matrix_dynamic1(int rows, int cols);
void read_matrix_dynamic1(int **matrix, int rows, int cols);
void print_matrix_dynamic1(int **matrix, int rows, int cols);
void free_matrix_dynamic1(int **matrix, int rows);
int *allocate_matrix_dynamic2(int rows, int cols);
void read_matrix_dynamic2(int *matrix, int rows, int cols);
void print_matrix_dynamic2(int *matrix, int rows, int cols);
void free_matrix_dynamic2(int *matrix);
int **allocate_matrix_dynamic3(int rows, int cols);
void read_matrix_dynamic3(int **matrix, int rows, int cols);
void print_matrix_dynamic3(int **matrix, int rows, int cols);
void free_matrix_dynamic3(int **matrix, int rows);
void find_max_in_rows(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int max[]);
void find_min_in_cols(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int min[]);
int main() {
int choice, rows, cols;
printf("Выберите метод выделения памяти:\n1. Статически\n2. Динамически (2D массив указателей)\n3. Динамически (1D массив)\n4. Динамически (массив указателей на строки)\n");
if (scanf("%d", &choice
) != 1 || choice
< 1 || choice
> 4) { return 1; // Ошибка выбора
}
// Чтение размеров матрицы
if (scanf("%d %d", &rows
, &cols
) != 2 || rows
< 1 || cols
< 1 || rows
> MAX_SIZE
|| cols
> MAX_SIZE
) { return 1; // Ошибка при считывании размеров матрицы
}
switch (choice) {
case 1: {
int matrix[MAX_SIZE][MAX_SIZE];
read_matrix_static(matrix, rows, cols);
print_matrix_static(matrix, rows, cols);
int max[MAX_SIZE]; // Для хранения максимальных элементов в строках
int min[MAX_SIZE]; // Для хранения минимальных элементов в столбцах
find_max_in_rows(matrix, rows, cols, max);
find_min_in_cols(matrix, rows, cols, min);
// вывод массивов
printf("\nМаксимальные элементы в каждой строке:\n"); for (int i = 0; i < rows; i++) {
if (i < rows - 1) {
}
}
printf("\nМинимальные элементы в каждом столбце:\n"); for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
break;
}
case 2: {
int **matrix = allocate_matrix_dynamic1(rows, cols);
if (matrix == NULL) {
return 1; // Ошибка при выделении памяти
}
read_matrix_dynamic1(matrix, rows, cols);
print_matrix_dynamic1(matrix, rows, cols);
int max[MAX_SIZE];
int min[MAX_SIZE];
find_max_in_rows(matrix, rows, cols, max);
find_min_in_cols(matrix, rows, cols, min);
printf("\nМаксимальные элементы в каждой строке:\n"); for (int i = 0; i < rows; i++) {
if (i < rows - 1) {
}
}
printf("\nМинимальные элементы в каждом столбце:\n"); for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
free_matrix_dynamic1(matrix, rows);
break;
}
case 3: {
int *matrix = allocate_matrix_dynamic2(rows, cols);
if (matrix == NULL) {
return 1; // Ошибка при выделении памяти
}
read_matrix_dynamic2(matrix, rows, cols);
print_matrix_dynamic2(matrix, rows, cols);
int max[MAX_SIZE];
int min[MAX_SIZE];
find_max_in_rows((int (*)[MAX_SIZE])matrix, rows, cols, max);
find_min_in_cols((int (*)[MAX_SIZE])matrix, rows, cols, min);
printf("\nМаксимальные элементы в каждой строке:\n"); for (int i = 0; i < rows; i++) {
if (i < rows - 1) {
}
}
printf("\nМинимальные элементы в каждом столбце:\n"); for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
free_matrix_dynamic2(matrix);
break;
}
case 4: {
int **matrix = allocate_matrix_dynamic3(rows, cols);
if (matrix == NULL) {
return 1; // Ошибка при выделении памяти
}
read_matrix_dynamic3(matrix, rows, cols);
print_matrix_dynamic3(matrix, rows, cols);
int max[MAX_SIZE];
int min[MAX_SIZE];
find_max_in_rows(matrix, rows, cols, max);
find_min_in_cols(matrix, rows, cols, min);
printf("\nМаксимальные элементы в каждой строке:\n"); for (int i = 0; i < rows; i++) {
if (i < rows - 1) {
}
}
printf("\nМинимальные элементы в каждом столбце:\n"); for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
free_matrix_dynamic3(matrix, rows);
break;
}
}
return 0;
}
// Чтение статической матрицы
void read_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (scanf("%d", &matrix
[i
][j
]) != 1) { exit(1); // Ошибка при считывании }
}
}
}
// Печать статической матрицы
void print_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
if (i < rows - 1) {
}
}
}
// Динамическое выделение: 2D массив указателей
int **allocate_matrix_dynamic1(int rows, int cols) {
int **matrix
= malloc(rows
* sizeof(int *)); if (matrix == NULL) return NULL;
for (int i = 0; i < rows; i++) {
matrix
[i
] = malloc(cols
* sizeof(int)); if (matrix[i] == NULL) {
for (int j = 0; j < i; j++) {
}
return NULL;
}
}
return matrix;
}
// Чтение динамической матрицы 1
void read_matrix_dynamic1(int **matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (scanf("%d", &matrix
[i
][j
]) != 1) { exit(1); // Ошибка при считывании }
}
}
}
// Печать динамической матрицы 1
void print_matrix_dynamic1(int **matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
if (i < rows - 1) {
}
}
}
// Освобождение памяти для динамической матрицы 1
void free_matrix_dynamic1(int **matrix, int rows) {
for (int i = 0; i < rows; i++) {
}
}
// Динамическое выделение: 1D массив
int *allocate_matrix_dynamic2(int rows, int cols) {
return malloc(rows
* cols
* sizeof(int)); }
// Чтение динамической матрицы 2
void read_matrix_dynamic2(int *matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (scanf("%d", &matrix
[i
* cols
+ j
]) != 1) { exit(1); // Ошибка при считывании }
}
}
}
// Печать динамической матрицы 2
void print_matrix_dynamic2(int *matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
printf("%d", matrix
[i
* cols
+ j
]); if (j < cols - 1) {
}
}
if (i < rows - 1) {
}
}
}
// Освобождение памяти для динамической матрицы 2
void free_matrix_dynamic2(int *matrix) {
}
// Динамическое выделение: массив указателей на строки
int **allocate_matrix_dynamic3(int rows, int cols) {
int **matrix
= malloc(rows
* sizeof(int *)); if (matrix == NULL) return NULL;
for (int i = 0; i < rows; i++) {
matrix
[i
] = malloc(cols
* sizeof(int)); if (matrix[i] == NULL) {
for (int j = 0; j < i; j++) {
}
return NULL;
}
}
return matrix;
}
// Чтение динамической матрицы 3
void read_matrix_dynamic3(int **matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (scanf("%d", &matrix
[i
][j
]) != 1) { exit(1); // Ошибка при считывании }
}
}
}
// Печать динамической матрицы 3
void print_matrix_dynamic3(int **matrix, int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (j < cols - 1) {
}
}
if (i < rows - 1) {
}
}
}
// Освобождение памяти для динамической матрицы 3
void free_matrix_dynamic3(int **matrix, int rows) {
for (int i = 0; i < rows; i++) {
}
}
// Функция для нахождения максимальных значений в каждой строке
void find_max_in_rows(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int max[]) {
for (int i = 0; i < rows; i++) {
max[i] = matrix[i][0];
for (int j = 1; j < cols; j++) {
if (matrix[i][j] > max[i]) {
max[i] = matrix[i][j];
}
}
}
}
// Функция для нахождения минимальных значений в каждом столбце
void find_min_in_cols(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int min[]) {
for (int j = 0; j < cols; j++) {
min[j] = matrix[0][j];
for (int i = 1; i < rows; i++) {
if (matrix[i][j] < min[j]) {
min[j] = matrix[i][j];
}
}
}
}
#include <stdio.h>
#include <stdlib.h>

#define MAX_SIZE 100

// Прототипы функций
void read_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols);
void print_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols);
int **allocate_matrix_dynamic1(int rows, int cols);
void read_matrix_dynamic1(int **matrix, int rows, int cols);
void print_matrix_dynamic1(int **matrix, int rows, int cols);
void free_matrix_dynamic1(int **matrix, int rows);
int *allocate_matrix_dynamic2(int rows, int cols);

void read_matrix_dynamic2(int *matrix, int rows, int cols);
void print_matrix_dynamic2(int *matrix, int rows, int cols);
void free_matrix_dynamic2(int *matrix);
int **allocate_matrix_dynamic3(int rows, int cols);
void read_matrix_dynamic3(int **matrix, int rows, int cols);
void print_matrix_dynamic3(int **matrix, int rows, int cols);
void free_matrix_dynamic3(int **matrix, int rows);
void find_max_in_rows(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int max[]);
void find_min_in_cols(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int min[]);

int main() {
    int choice, rows, cols;

    printf("Выберите метод выделения памяти:\n1. Статически\n2. Динамически (2D массив указателей)\n3. Динамически (1D массив)\n4. Динамически (массив указателей на строки)\n");

    if (scanf("%d", &choice) != 1 || choice < 1 || choice > 4) {
        printf("n/a\n");
        return 1; // Ошибка выбора
    }

    // Чтение размеров матрицы
    if (scanf("%d %d", &rows, &cols) != 2 || rows < 1 || cols < 1 || rows > MAX_SIZE || cols > MAX_SIZE) {
        printf("n/a\n");
        return 1; // Ошибка при считывании размеров матрицы
    }

    switch (choice) {
        case 1: {
            int matrix[MAX_SIZE][MAX_SIZE];
            read_matrix_static(matrix, rows, cols);
            print_matrix_static(matrix, rows, cols);

            int max[MAX_SIZE]; // Для хранения максимальных элементов в строках
            int min[MAX_SIZE]; // Для хранения минимальных элементов в столбцах
            find_max_in_rows(matrix, rows, cols, max);
            find_min_in_cols(matrix, rows, cols, min);

            // вывод массивов
            printf("\nМаксимальные элементы в каждой строке:\n");
            for (int i = 0; i < rows; i++) {
                printf("%d", max[i]);
                if (i < rows - 1) {
                    printf(" ");
                }
            }
            printf("\nМинимальные элементы в каждом столбце:\n");
            for (int j = 0; j < cols; j++) {
                printf("%d", min[j]);
                if (j < cols - 1) {
                    printf(" ");
                }
            }
            break;
        }
        case 2: {
            int **matrix = allocate_matrix_dynamic1(rows, cols);
            if (matrix == NULL) {
                printf("n/a\n");
                return 1; // Ошибка при выделении памяти
            }
            read_matrix_dynamic1(matrix, rows, cols);
            print_matrix_dynamic1(matrix, rows, cols);

            int max[MAX_SIZE];
            int min[MAX_SIZE];
            find_max_in_rows(matrix, rows, cols, max);
            find_min_in_cols(matrix, rows, cols, min);

            printf("\nМаксимальные элементы в каждой строке:\n");
            for (int i = 0; i < rows; i++) {
                printf("%d", max[i]);
                if (i < rows - 1) {
                    printf(" ");
                }
            }
            printf("\nМинимальные элементы в каждом столбце:\n");
            for (int j = 0; j < cols; j++) {
                printf("%d", min[j]);
                if (j < cols - 1) {
                    printf(" ");
                }
            }
            free_matrix_dynamic1(matrix, rows);
            break;
        }
        case 3: {
            int *matrix = allocate_matrix_dynamic2(rows, cols);
            if (matrix == NULL) {
                printf("n/a\n");
                return 1; // Ошибка при выделении памяти
            }
            read_matrix_dynamic2(matrix, rows, cols);
            print_matrix_dynamic2(matrix, rows, cols);

            int max[MAX_SIZE];
            int min[MAX_SIZE];
            find_max_in_rows((int (*)[MAX_SIZE])matrix, rows, cols, max);
            find_min_in_cols((int (*)[MAX_SIZE])matrix, rows, cols, min);

            printf("\nМаксимальные элементы в каждой строке:\n");
            for (int i = 0; i < rows; i++) {
                printf("%d", max[i]);
                if (i < rows - 1) {
                    printf(" ");
                }
            }
            printf("\nМинимальные элементы в каждом столбце:\n");
            for (int j = 0; j < cols; j++) {
                printf("%d", min[j]);
                if (j < cols - 1) {
                    printf(" ");
                }
            }
            free_matrix_dynamic2(matrix);
            break;
        }
        case 4: {
            int **matrix = allocate_matrix_dynamic3(rows, cols);
            if (matrix == NULL) {
                printf("n/a\n");
                return 1; // Ошибка при выделении памяти
            }
            read_matrix_dynamic3(matrix, rows, cols);
            print_matrix_dynamic3(matrix, rows, cols);

            int max[MAX_SIZE];
            int min[MAX_SIZE];
            find_max_in_rows(matrix, rows, cols, max);
            find_min_in_cols(matrix, rows, cols, min);

            printf("\nМаксимальные элементы в каждой строке:\n");
            for (int i = 0; i < rows; i++) {
                printf("%d", max[i]);
                if (i < rows - 1) {
                    printf(" ");
                }
            }
            printf("\nМинимальные элементы в каждом столбце:\n");
            for (int j = 0; j < cols; j++) {
                printf("%d", min[j]);
                if (j < cols - 1) {
                    printf(" ");
                }
            }
            free_matrix_dynamic3(matrix, rows);
            break;
        }
    }

    return 0;
}

// Чтение статической матрицы
void read_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            if (scanf("%d", &matrix[i][j]) != 1) {
                printf("n/a\n");
                exit(1); // Ошибка при считывании
            }
        }
    }
}

// Печать статической матрицы
void print_matrix_static(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            printf("%d", matrix[i][j]);
            if (j < cols - 1) {
                printf(" ");
            }
        }
        if (i < rows - 1) {
            printf("\n");
        }
    }
}

// Динамическое выделение: 2D массив указателей
int **allocate_matrix_dynamic1(int rows, int cols) {
    int **matrix = malloc(rows * sizeof(int *));
    if (matrix == NULL) return NULL;

    for (int i = 0; i < rows; i++) {
        matrix[i] = malloc(cols * sizeof(int));
        if (matrix[i] == NULL) {
            for (int j = 0; j < i; j++) {
                free(matrix[j]);
            }
            free(matrix);
            return NULL;
        }
    }
    return matrix;
}

// Чтение динамической матрицы 1
void read_matrix_dynamic1(int **matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            if (scanf("%d", &matrix[i][j]) != 1) {
                printf("n/a\n");
                exit(1); // Ошибка при считывании
            }
        }
    }
}

// Печать динамической матрицы 1
void print_matrix_dynamic1(int **matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            printf("%d", matrix[i][j]);
            if (j < cols - 1) {
                printf(" ");
            }
        }
        if (i < rows - 1) {
            printf("\n");
        }
    }
}

// Освобождение памяти для динамической матрицы 1
void free_matrix_dynamic1(int **matrix, int rows) {
    for (int i = 0; i < rows; i++) {
        free(matrix[i]);
    }
    free(matrix);
}

// Динамическое выделение: 1D массив
int *allocate_matrix_dynamic2(int rows, int cols) {
    return malloc(rows * cols * sizeof(int));
}

// Чтение динамической матрицы 2
void read_matrix_dynamic2(int *matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            if (scanf("%d", &matrix[i * cols + j]) != 1) {
                printf("n/a\n");
                exit(1); // Ошибка при считывании
            }
        }
    }
}

// Печать динамической матрицы 2
void print_matrix_dynamic2(int *matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            printf("%d", matrix[i * cols + j]);
            if (j < cols - 1) {
                printf(" ");
            }
        }
        if (i < rows - 1) {
            printf("\n");
        }
    }
}

// Освобождение памяти для динамической матрицы 2
void free_matrix_dynamic2(int *matrix) {
    free(matrix);
}

// Динамическое выделение: массив указателей на строки
int **allocate_matrix_dynamic3(int rows, int cols) {
    int **matrix = malloc(rows * sizeof(int *));
    if (matrix == NULL) return NULL;

    for (int i = 0; i < rows; i++) {
        matrix[i] = malloc(cols * sizeof(int));
        if (matrix[i] == NULL) {
            for (int j = 0; j < i; j++) {
                free(matrix[j]);
            }
            free(matrix);
            return NULL;
        }
    }
    return matrix;
}

// Чтение динамической матрицы 3
void read_matrix_dynamic3(int **matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            if (scanf("%d", &matrix[i][j]) != 1) {
                printf("n/a\n");
                exit(1); // Ошибка при считывании
            }
        }
    }
}

// Печать динамической матрицы 3
void print_matrix_dynamic3(int **matrix, int rows, int cols) {
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            printf("%d", matrix[i][j]);
            if (j < cols - 1) {
                printf(" ");
            }
        }
        if (i < rows - 1) {
            printf("\n");
        }
    }
}

// Освобождение памяти для динамической матрицы 3
void free_matrix_dynamic3(int **matrix, int rows) {
    for (int i = 0; i < rows; i++) {
        free(matrix[i]);
    }
    free(matrix);
}

// Функция для нахождения максимальных значений в каждой строке
void find_max_in_rows(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int max[]) {
    for (int i = 0; i < rows; i++) {
        max[i] = matrix[i][0];
        for (int j = 1; j < cols; j++) {
            if (matrix[i][j] > max[i]) {
                max[i] = matrix[i][j];
            }
        }
    }
}

// Функция для нахождения минимальных значений в каждом столбце
void find_min_in_cols(int matrix[MAX_SIZE][MAX_SIZE], int rows, int cols, int min[]) {
    for (int j = 0; j < cols; j++) {
        min[j] = matrix[0][j];
        for (int i = 1; i < rows; i++) {
            if (matrix[i][j] < min[j]) {
                min[j] = matrix[i][j];
            }
        }
    }
}