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

Сортировка матрицы методом пузырька - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Отобразить главную и побочную диагонали симметрично относительно горизонтальной оси http://www.cyberforum.ru/cpp-beginners/thread1175056.html
Заполнить матрицу случайными числами. Отобразить главную и побочную диагонали симметрично относительно горизонтальной оси.
C++ Линейный список и функции обработки Написать программу с функциями, которая: а)подсчитывает количество вхождений элемента C в список M ; б)удаляет со списка M все вхождения элемента C; в)печатает в обратном порядке элементы списка M. помогите..... http://www.cyberforum.ru/cpp-beginners/thread1175053.html
C++ Необработанное исключение в "0x776315de" в "c++1.exe": 0xC0000005: Нарушение прав доступа при записи "0x40e000
Здравствуйте. Только начал работать с динамическим массивом, но не могу понять почему появляется эта ошибка. Работаю с библиотекой sfml. Пришлось самому реализовывать функцию ввода через события нажатий различных клавиш. Реализован весь ввод русского алфавита. Если ничего не нажимать, а просто закрыть окно, то нет этой ошибки. Если что-нибудь вводить , а затем нажать Esc или "крестик" то...
Стеки, функции добавления и удаления элементов C++
Программа на стеки выводит на экран 9876543210 ..помогите сделать так, чтобы можно было вводить вручную, удалять элементы из стека, добавлять,и в случае если эллементов не будет, высвечивалась надпись "Стек пуст" #include <iostream> using namespace std; struct List { int x;
C++ Ввести строку,переделать последовательности цифровых символов в числа и найти их сумму http://www.cyberforum.ru/cpp-beginners/thread1175031.html
помогите пожалуйста,новичок в программировании,хочу решить эту задачу,спасибо заранее) ввести ряд,переделать последовательности цифровых символов на нем на числа и найти их сумму
C++ Builder Найти фамилию студента, который имеет наибольшее количество пропусков занятий Добрый вечер. Есть программа, Обработка списка студентов, в которой нужно найти: фамилию студента, который имеет наибольшее количество пропусков занятий в кнопке "Обчислить". На данный момент там находится условие: Список студентов, обучающихся только на 4 и 5. Подскажите кто знает как это сделать, буду благодарен Так же прилагается полная программа. void __fastcall... подробнее

Показать сообщение отдельно
DirectX
 Аватар для DirectX
23 / 17 / 6
Регистрация: 07.10.2013
Сообщений: 47
14.05.2014, 21:19     Сортировка матрицы методом пузырька
Здесь лучше рассматривать квадратную матрицу так --> в не квадратной матрице диагональ просто теряет свой смысл(матрица как бы усекается к квадратной).

как-то так
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
#include <iostream>
#include <cmath>
using namespace std;
 
int main()
{
    int n;
    cout << "Enter n: ";
    cin >> n;
 
    // allocate memory
    int ** a = new int * [n];
    for (int i = 0; i < n; i++)
        a[i] = new int[n];
 
    int * x = new int[n];
 
    int * temp = new int[n];
 
    // input matrix
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++)
            cin >> a[i][j];
 
    // output before transformation(sort to last column of matrix)
    cout << "Before transformation:\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n - 1; j++)
            cout << a[i][j] << ' ';
        cout << a[i][n - 1] << endl;
    }
 
    // transforamtion(sort to last column of matrix)
    for (int k = 0; k < n; k++)
    {
        for (int i = 0; i < n - k - 1; i++)
            if (a[i][n - 1] > a[i + 1][n - 1])
            {
                // cout << "elements: " << a[i][n -1] << " | " << a[i + 1][n -1] << endl; // <-- debug info
            
                // swap(a[i][0 <= j < n], a[i + 1][0 <= j < n]) start
                //==================================================================//
                // copy temp ---> a[i][0 <= j < n];
                for (int j = 0; j < n; j++)
                    temp[j] = a[i][j];
 
                // assign a[i + 1][0 <= j < n] ---> a[i][0 <= j < n]
                for (int j = 0; j < n; j++)
                    a[i][j] = a[i + 1][j];
 
                // assign a[i][0 <= j < n] ---> temp
                for (int j = 0; j < n; j++)
                    a[i + 1][j] = temp[j];
                //==================================================================//
                // end swap
            }
    }
 
    // output after transformation(sort to last column of matrix)
    cout << "After transformation:\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n - 1; j++)
            cout << a[i][j] << ' ';
        cout << a[i][n - 1] << endl;
    }
 
    // create array(vector) x with main diagonal of natrix(a)
    for (int i = 0; i < n; i++)
        x[i] = a[i][i];
 
    // output array(vector) x
    cout << "Vector X:\n";
    for (int i = 0; i < n - 1; i++)
        cout << x[i] << ' ';
    cout << x[n - 1] << endl;
 
    // free memory
    for (int i = 0; i < n; i++)
        delete [] a[i];
    delete [] a;
 
    delete [] x;
 
    delete [] temp;
 
    cin.get();
    cin.get();
    return 0;
}

Не по теме:

Sorry за английские комментарии(пытаюсь таким способом повышать навыки английского языка)

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