Форум программистов, компьютерный форум CyberForum.ru

Сортировка матрицы (создайте блок-схему. Пожалуйста) - C++

Восстановить пароль Регистрация
 
canales
Сообщений: n/a
15.05.2013, 21:22     Сортировка матрицы (создайте блок-схему. Пожалуйста) #1
Нужно создать двумерный массив размером 5 х 7 (пять строк, семь столбиков). Заполнить его случайно целыми числами, в районе от 0 до 30. Вывести этот массив на экран. Затем нужно отсортировать строки массива так, чтобы первой шла строка, сумма элементов которой была меньше, чем других. И так далее, по росту

Кликните здесь для просмотра всего текста
Потрібно створити двовимірний масив, розміром 5 х 7 (п'ять рядків, сім стовпчиків). Заповнити його випадково цілими числами, в районі від 0 до 30. Вивести цей масив на екран. Потім потрібно відсортувати рядка масиву так, щоб першої йшла рядок, сума елементів якої була менше, ніж інших. І так далі, по зростанню.

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
#include <iostream>
#include <iomanip>
#include <stdlib.h>
#include <time.h>
 
using namespace std;
 
void initMatrix(int[][7], const int, const int);
void replaceColumn(int[][7], const int, int, int);
void printMatrix(int[][7], const int, const int);
   
int main()
{
    const int column = 5, row = 7;
    int matrix[column][row];
    int counter, result, columnMin;
    
    srand(time(NULL));
//ініціалізіуємо двовимірний масив випадковими величинами,
//потім друкуємо його
init Matrix(matrix, column, row);
cout << "\nNoSorted array" << endl << endl;
printMatrix(matrix, column, row);
 
//робимо проходи стільки разів, скільки рядків у масиві
for(int N = 0; N < column - 1; N++)
{
    result = row * 30;
 
    //аналізуємо масив і знаходимо рядок,
    //сума елементів якої мінімальна
    for(int i = N; i < column; i++)
{
    //обнулюємо лічильник суми елементів рядка
    counter = 0;
 
    //проходимо по елементам данного рядка
    //і вважаємо суму
    for(int j = 0; j < row; j++)
    counter += matrix[i][j];
 
    //result в підсумку буде зберігати значення мінімальної суми
    //columnMin буде зберігати значення рядка, в якій
    //була знайдена мінімальна сума
    if(result > counter)
{
    result = counter;
    columnMin = i;
    }
}
 
    replaceColumn(matrix, row, N, columnMin);
}
 
    //друкуємо відсортований масив
    cout << "\nSorted array" << endl << endl;
    printMatrix(matrix, column, row);
 
    return 0;
}
 
    //ініціалізація двомiрного масива
    void initMatrix(int matrix[][7], const int column, const int row)
{
    for(int i = 0; i < column; i++)
    for(int j = 0; j < row; j++)
    matrix[i][j] = rand() % 30;
}
 
    //міняємо рядка масиву місцями
    void replaceColumn(int matrix[][7], const int row, int N, int columnMin)
{
    int buffer[row];
 
    for(int j = 0; j < row; j++)
{
    buffer[j] = matrix[columnMin][j];
    matrix[columnMin][j] = matrix[N][j];
    matrix[N][j] = buffer[j];
    }
}
 
    //друк двомiрного масива
    void printMatrix(int matrix[][7], const int column, const int row)
{
     for(int i = 0; i < column; i++)
{
     for(int j = 0; j < row; j++)
     cout << setw(3) << matrix[i][j];
 
     cout << endl;
    }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.05.2013, 21:22     Сортировка матрицы (создайте блок-схему. Пожалуйста)
Посмотрите здесь:

Помогите пожалуйста сделать блок-схему C++
создайте блок-схему C++
Написать блок-схему C++
Пожалуйста составьте блок схему C++
C++ Составьте блок схему пожалуйста кому не трудно
Циклический алгоритм.пожалуйста напишите программу.и если не сложно блок-схему C++
Составьте пожалуйста блок схему для кода С++ C++
C++ Алгоритм Дейкстры для матрицы смежности А размером NxN, нарисовать блок-схему по коду

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 10:25. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru