Форум программистов, компьютерный форум, киберфорум
Fon Eberkopff
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

laba6_matrix

Запись от Fon Eberkopff размещена 26.10.2016 в 19:05
Показов 1378 Комментарии 0

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*****************************************************
* laba6_matrix.c    25.10.2016
* 
* Дана прямоугольная матрица, которая заполняется
* случайными числами.
* Для каждого столбца исходной матрицы найти минимальный
* элемент и сохранить его в одномерный массив.
* Отсортировать столбцы в матрице в порядке возрастания
* значений элементов массива минимальных значений
* (сортировочный ключ)
******************************************************/
 
#include <stdio.h> /* printf, scanf */
#include <stdlib.h> /* srand, rand */ 
#include <time.h> /* time */
 
#define R 5 // строки
#define COLUMN 7 // столбцы
#define M 20 // деление по модулю 20
 
int main()
{
    // устанавливаем исходное число для последовательности,
    // генерируемой функцией rand()
    srand((unsigned) time(NULL));
 
    int a[R][COLUMN], b[COLUMN], c[COLUMN], i, j;
 
    // инициализация массива случайными числами    
    for(i = 0; i < R; i++)
        for(j = 0; j < COLUMN; j++)
            a[i][j] = rand() % M + 1;
 
    printf("\n-----Матрица до сортировки\n");
    for(i = 0; i < R; i++) {
        printf("\n\t");
        for(j = 0; j < COLUMN; j++) {
            printf("%4d", a[i][j]);
        }
    }
 
    // поиск минимального элемента в каждом из столбцов
    for(i = 0; i < COLUMN; i++)
        for(j = 0; j < R-1; j++) {
            b[i] = a[j][i];
            if(a[j][i] > a[j+1][i])
                b[i] = a[j+1][i];
        }
 
    printf("\n\n-----Вектор минимальных значений \n");
    printf("\n\t");
    for(i = 0; i < COLUMN; i++)
        printf("%4d", b[i]);
 
    // вектор значений индексов массива от 0 до С-1
    printf("\n\t");
    for(i = 0; i < COLUMN; i++)
            c[i] = i; // изначально 
 
    // сортируем минимальные значения и соответствующие им значения индексов 
    for(i = 0; i < COLUMN - 1; i++) {
        for(j = i + 1; j < COLUMN; j++) {
            if( b[i] > b[j]) {
                int t = b[j];
                b[j] = b[i];
                b[i] = t;
                t = c[j];
                c[j] = c[i];
                c[i] = t;
            }
        }
    }
 
    printf("\n-----Вектор упорядоченных минимальных значений \n");
    printf("\n\t");
    for(i = 0; i < COLUMN; i++)
        printf("%4d", b[i]);
 
 
    printf("\n\n-----Вывод матрицы по сортировочному ключу \n");
    for(i = 0; i < R; i++) {
        printf("\n\t");
        for(j = 0; j < COLUMN; j++) {
            int new_j;
            new_j = c[j];
            printf("%4d", a[i][new_j]);
        }
    }
    
    printf("\n\n");
 
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 0
Комментарии
 
Новые блоги и статьи
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru