Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 02.07.2019
Сообщений: 32

Сортировка с компаратором

04.07.2019, 10:17. Показов 5366. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста написать сортировку компаратором, есть пузырьковая сортировка . Небходимо добавить к сортировке функцию компаратор, т.е. возможность сравнивать ее как в убывающей последовательности так и в возрастающей. Компаратор необходимо написать применив лямбда функции.
Не могу понять как написать компаратор и куда его вписать.

C++ (Qt)
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
#include <iostream>
 
using namespace std;
 
int main()
{
    int *arr; 
    int size; 
    cout << "n = ";
    cin >> size;
    if (size <= 0) {
        cerr << "Invalid size" << endl;
        return 1;
    }
    arr = new int[size]; 
    for (int i = 0; i < size; i++) {
        cout << "arr[" << i << "] = ";
        cin >> arr[i];
    }
    int temp; 
    for (int i = 0; i < size - 1; i++) {
        for (int j = 0; j < size - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
    for (int i = 0; i < size; i++) {
        cout << arr[i] << " ";
    }
    cout << endl;
    delete[] arr; 
    return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.07.2019, 10:17
Ответы с готовыми решениями:

Сортировка с собственным компаратором
class Comprasion def self.compare(a, b) c1 = findMaxSub(a) c2 = findMaxSub(b) c1 &lt;=&gt; c2 end def...

Сортировка коллекции List с компаратором
Подскажите пожалуйста как создать компаратор для сортировка ArrayList типа String. Везде в примерах показана сортировка коллекции с...

измерение тока компаратором или ОУ
Коллеги! Что-то я туплю. Если не сложно - набросайте схему или ткните ссылку. Как измерить (сигнализировать) ток порядка 10 мА с...

9
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
04.07.2019, 10:29
Лучший ответ Сообщение было отмечено АнтонВарушин как решение

Решение

АнтонВарушин,
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
#include <iostream>
 
using namespace std;
 
template<class Comp>
void my_bubble_sort(int* arr, int size, Comp&& f)
{
    int temp;
    for (int i = 0; i < size - 1; i++) {
        for (int j = 0; j < size - i - 1; j++) {
            if (f(arr[j + 1], arr[j])) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}
 
int main()
{
    int *arr;
    int size;
    cout << "n = ";
    cin >> size;
    if (size <= 0) {
        cerr << "Invalid size" << endl;
        return 1;
    }
    arr = new int[size];
    for (int i = 0; i < size; i++) {
        cout << "arr[" << i << "] = ";
        cin >> arr[i];
    }
 
    auto less = [](int lh, int rh) { return lh < rh; };
    my_bubble_sort(arr, size, less);
 
    for (int i = 0; i < size; i++) {
        cout << arr[i] << " ";
    }
    cout << endl;
    delete[] arr;
    return 0;
}
1
0 / 0 / 0
Регистрация: 02.07.2019
Сообщений: 32
04.07.2019, 12:27  [ТС]
А зачем нам нужен шаблон? И почему ми компаратор вставили в if нашего цикла?
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
04.07.2019, 12:41
Цитата Сообщение от АнтонВарушин Посмотреть сообщение
А зачем нам нужен шаблон?
а какая альтернатива?
Цитата Сообщение от АнтонВарушин Посмотреть сообщение
И почему ми компаратор вставили в if нашего цикла?
а ты бы куда его вставил? по моему его больше некуда вставлять.
0
0 / 0 / 0
Регистрация: 02.07.2019
Сообщений: 32
04.07.2019, 12:48  [ТС]
Может вместо шаблона тип int?
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
04.07.2019, 13:10
Цитата Сообщение от АнтонВарушин Посмотреть сообщение
Может вместо шаблона тип int?
не в инте дело, дело в критериях сортировки. через механизм шаблонов можно подставлять разные критерии в один и тот же код. удобно, компактно.
0
0 / 0 / 0
Регистрация: 02.07.2019
Сообщений: 32
04.07.2019, 13:13  [ТС]
То есть , шаблон нужен для разных типов, double char float?
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
04.07.2019, 13:38
Цитата Сообщение от АнтонВарушин Посмотреть сообщение
То есть , шаблон нужен для разных типов, double char float?
смотря как ты компаратор напишешь, шаблон может быть применен ко всему компаратору а может только к аргументам.
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
template <typename T>
struct Comp1
{
    bool operator()(T i, T j)
    {
        return i < j;
    }
};
 
struct Comp2
{
    bool operator()(int i, int j)
    {
        return i < j;
    }
};
 
template<class Comp>
void my_bubble_sort(int* arr, int size, Comp&& f)
{
    int temp;
    for (int i = 0; i < size - 1; i++) {
        for (int j = 0; j < size - i - 1; j++) {
            if (f(arr[j + 1], arr[j])) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}
 
int main()
{
    my_bubble_sort(0, 0, Comp1<int>{} );
    my_bubble_sort(0, 0, Comp2{} );
 
    return 0;
}
Добавлено через 2 минуты
то есть в данном случае, шаблон служит для того что бы либо менять тип компаратора, либо типы аргументов.
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
04.07.2019, 13:41
АнтонВарушин, можно без шаблона в данном конкретном случае, это я по привычке
C++
1
void my_bubble_sort(int* arr, int size, bool(*f)(int,int)) // просто подправьте сигнатуру функции сортировки
0
0 / 0 / 0
Регистрация: 02.07.2019
Сообщений: 32
04.07.2019, 13:45  [ТС]
Спасибо, думаю я понял)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.07.2019, 13:45
Помогаю со студенческими работами здесь

Первый опыт с аналоговым компаратором
Всем привет, Решил изучить компаратор ATtiny2313. Подаю 2.5V на AIN1, а вход AIN0 подключаю к переменному резистору. Исходный...

Сравнение двух сигналов встроенным компаратором msp430g2553
Добрый день, форумчане! Нашел в просторах сообщества отличную статью про использование компаратора в msp430g2553:...

Сортировка выбором, сортировка вставкой, сортировка заменой, сортировка обменом ("пузырьковая" сортировка)
Создать класс, содержащий массив и реализующий алгоритмы сортировки и бинарного поиска в этом массиве. Класс описать с помощью...

Блок схема.Сортировка «Пузырьком», Сортировка методом «Последовательных перестановок», Сортировка «Вставками»
Помогите, нужны блок схемы Сортировка «Вставками» Program Vstavka; uses dos; Type mass=array of integer; Var i,b,n,j,a:...

Разработать программу сортировки: сортировка перестановкой, сортировка вставкой, быстрая сортировка
Задание: Разработать программу сортировки: - сортировка перестановкой - сортировка вставкой - быстрая сортировка


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru