#include <stdlib.h>
#include <stdio.h>
#include <time.h>
int compare(const void* a, const void* b)
{
return *((int*)a) - *((int*)b);
}
int equals(int* a, int* b, int k)
{
int i;
for (i = 0; i < k; ++i) {
if (a[i] != b[i]) {
return 0;
}
}
return 1;
}
int main(void)
{
int n = 0;
int** a = NULL;
int i = 0, j = 0;
int k = 0;
do {
printf("N: ");
scanf_s("%i", &n);
} while (n <= 2);
srand((unsigned)time(NULL));
a = (int**)malloc(n * sizeof(int*));
for (i = 0; i < n; ++i) {
a[i] = (int*)malloc(n * sizeof(int));
}
for (i = 0; i < n; ++i) {
for (j = 0; j < n; ++j) {
a[i][j] = 1 + rand() % (n >> 1);
}
}
for (i = 0; i < n; ++i) {
for (j = 0; j < n; ++j) {
printf("%4i", a[i][j]);
}
puts("");
}
for (i = 0; i < n; ++i) {
qsort(a[i], n, sizeof(a[0]), compare);
}
do {
printf("K: ");
scanf_s("%i", &k);
} while (k >= n || k <= 0);
for (i = 1; i < n; ++i) {
if (!equals(a[0], a[i], k)) {
break;
}
}
system("chcp 1251 > nul");
if (i != n) {
puts("Нет!");
} else {
puts("Да!");
}
for (i = 0; i < n; ++i) {
for (j = 0; j < n; ++j) {
printf("%4i", a[i][j]);
}
puts("");
}
for (i = 0; i < n; ++i) {
free(a[i]);
}
free(a);
system("pause > nul");
}
C/C++
Как найти несколько минимальных значений массива в си?
последовательно. Сначала самый маленький, потом побольше, потом следующий
Талгат Аубакиров
а как это сделать для заданного количество минимальных чисел?
Похожие вопросы
- Как в функции распечатать двумерный динамический массив в Си
- Найти минимальный элемент массива
- Инкрементировать строки массива указателей. (Си)
- Заменить нулями элементы массива, которые расположены между первым минимальным и последним максимальным элементами масси
- Упорядочить элементы массива по возрастанию на языке Си
- Помогите добавить ввод чисел в массив матрицы на языке Си
- Почему не меняется значения в массиве
- Имя массива после инициализации принимает адрес в стеке, который указывает на адрес в куче? (Си)
- Как обработать этот массив на языке Си?
- Одномерные массивы на языке си