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

Cортировка массива пузырьковым методом и методом вставок

24.05.2018, 20:30. Показов 956. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Прошу помочь, хочу сделать приложение для сравнения 2 сортировок
Пузырьковый метод и Метод вставок

1. Создается массив
2. Выбирается метод сортировки
3. Сортировка
4. Подсчет результатов и времени

Нашел код аналогичной программы в интернете, но на Visual Studio 2018 - С++ не запускается
Начал исправлять ошибки, походу сделал только хуже, после 3 часов в пустую решил спросить тут.

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
94
95
96
97
98
99
100
101
102
103
104
#include <iostream>
#include "stdafx.h"
#include <time.h>
#include <conio.h>
#include <windows.h> 
#include <stdlib.h>
 
//#pragma argsused
using namespace std;
 
void insert(int *a, int n) // ФУНКЦИЯ ВСТАВОК
{
    int i, j, t; // объявление переменных
    for (i = 1; i<n; i++)
    {
        t = a[i]; // запоминается элемент для вставки
        for (j = i - 1; j >= 0 && t<a[j]; j--) // ищем место для вставки
            a[j + 1] = a[j]; // сдвиг на одну позицию
        a[j + 1] = t;
    }
}
void buble(int *a, int n) // функция пузырька
{
    int i, j, t; // объявление переменных
    for (i = 0; i <= n - 1; i++)
    {
        for (j = 0; j <= n - 2 - i; j++)
        {
            if (a[j] >a[j + 1]) // сравниваем пару соседних элементов
            {
                t = a[j]; // и меняем их местами если это требуется
                a[j] = a[j + 1];
                a[j + 1] = t;
            }
        }
    }
}
int main(int argc, char* argv[])
{
    char b;
    char buf[256];
    char buf1[256];
    char buf2[256];
    char cout;
    char endl;
    int cin;
    int n;
    typedef long clock_t; // тип данных времени
    clock_t t; // t - время выполнения программы
    char str1[100] = "Введите количество элементов для сортировки: ";
    char str2[100];
    char str3[100];
    CharToOem (str1, buf);
    cout << buf << endl;
    cin >> n;
    int* a = new int; // создание, указание кол-ва элементов
    for (int i = 0; i <= n; i++)
        a[i] = rand();
    strcpy(str1, "Первичный массив: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    for (int i = 0; i<n; i++)
    {
        cout << " a [" << i << "] =" << a[i] << ' ';
        if (!((i + 1) % 5)) cout << "\n"; // массив выводится по 5 значений в строке
    };
    cout << endl;
    strcpy(str1, "Выберите тип сортировки: ");
    strcpy(str2, "1. Сортировка методом простых вставок");
    strcpy(str3, "2. Сортировка методом пузырька ");
    CharToOem(str1, buf);
    CharToOem(str2, buf1);
    CharToOem(str3, buf2);
    cout << buf << endl
        << buf1 << endl
        << buf2 << endl;
    cin >> b;
    strcpy(str1, "Отсортированные элементы: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    if (b = '1')
    {
        insert(a, n); // вызов функции сортировки
    }
    if (b = '2')
    {
        buble(a, n); // вызов функции
    }
    for (int i = 0; i<n; i++)
    {
        cout << " a [" << i << "] =" << a[i] << ' ';
        if (!((i + 1) % 5)) cout << "\n";
    }
    cout << endl; // подсчёт времени выполнения программы
    strcpy(str1, "Время сортировки в мс: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    t = (clock() / CLOCKS_PER_SEC) * 60; // функция clock () возвращает время исп программы
    cout << t; // как значение типа clock_t объявленного ранее это // значение можно перевести в секунды
               // поделив на определенную в библиотеке time. h константу CLOCKS_PER_SEC
    getchar();
    getchar();
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.05.2018, 20:30
Ответы с готовыми решениями:

Сортировка массива пузырьковым методом и методом вставки
нужно написать программу которая будет делать сортировку этими способами в массиве 3x10, две кнопки, таблица (3х10), собственно...

Реализовать сортировку по росту (по убыванию) методом вставок и методом слияния
Добавлено через 1 час 27 минут ... Список лист заполняется экземплярами класса: void...

Сортировка двумерного массива методом вставок
Создать программу, сортирующую методом вставок двумерный массив целых чисел. При этом самое маленькое число должно оказаться в первом...

3
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
24.05.2018, 20:40

Не по теме:

Цитата Сообщение от Akmalov Посмотреть сообщение
Visual Studio 2018 - С++
где взял? :facepalm:



Добавлено через 2 минуты
Цитата Сообщение от Akmalov Посмотреть сообщение
Начал исправлять ошибки, походу сделал только хуже, после 3 часов в пустую решил спросить тут.
тут оригинал кода или твой исправленный?
0
0 / 0 / 0
Регистрация: 22.07.2017
Сообщений: 5
25.05.2018, 05:31  [ТС]
Ошибка - Visual Studio 2017

Код оригинал с наименьшими правками
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
25.05.2018, 07:31
Akmalov, собирается, не проверял на логические ошибки, три не нужные переменные за комментировал.
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
94
95
96
97
98
99
100
101
102
103
104
105
106
#define _CRT_SECURE_NO_WARNINGS
 
#include <iostream>
//#include "stdafx.h"
#include <time.h>
#include <conio.h>
#include <windows.h> 
#include <stdlib.h>
 
//#pragma argsused
using namespace std;
 
void insert(int *a, int n) // ФУНКЦИЯ ВСТАВОК
{
    int i, j, t; // объявление переменных
    for (i = 1; i<n; i++)
    {
        t = a[i]; // запоминается элемент для вставки
        for (j = i - 1; j >= 0 && t<a[j]; j--) // ищем место для вставки
            a[j + 1] = a[j]; // сдвиг на одну позицию
        a[j + 1] = t;
    }
}
void buble(int *a, int n) // функция пузырька
{
    int i, j, t; // объявление переменных
    for (i = 0; i <= n - 1; i++)
    {
        for (j = 0; j <= n - 2 - i; j++)
        {
            if (a[j] >a[j + 1]) // сравниваем пару соседних элементов
            {
                t = a[j]; // и меняем их местами если это требуется
                a[j] = a[j + 1];
                a[j + 1] = t;
            }
        }
    }
}
int main(int argc, char* argv[])
{
    char b;
    char buf[256];
    char buf1[256];
    char buf2[256];
    /*char cout;
    char endl;
    int cin;*/
    int n;
    typedef long clock_t; // тип данных времени
    clock_t t; // t - время выполнения программы
    char str1[100] = "Введите количество элементов для сортировки: ";
    char str2[100];
    char str3[100];
    CharToOem (str1, buf);
    cout << buf << endl;
    cin >> n;
    int* a = new int; // создание, указание кол-ва элементов
    for (int i = 0; i <= n; i++)
        a[i] = rand();
    strcpy(str1, "Первичный массив: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    for (int i = 0; i<n; i++)
    {
        cout << " a [" << i << "] =" << a[i] << ' ';
        if (!((i + 1) % 5)) cout << "\n"; // массив выводится по 5 значений в строке
    };
    cout << endl;
    strcpy(str1, "Выберите тип сортировки: ");
    strcpy(str2, "1. Сортировка методом простых вставок");
    strcpy(str3, "2. Сортировка методом пузырька ");
    CharToOem(str1, buf);
    CharToOem(str2, buf1);
    CharToOem(str3, buf2);
    cout << buf << endl
        << buf1 << endl
        << buf2 << endl;
    cin >> b;
    strcpy(str1, "Отсортированные элементы: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    if (b = '1')
    {
        insert(a, n); // вызов функции сортировки
    }
    if (b = '2')
    {
        buble(a, n); // вызов функции
    }
    for (int i = 0; i<n; i++)
    {
        cout << " a [" << i << "] =" << a[i] << ' ';
        if (!((i + 1) % 5)) cout << "\n";
    }
    cout << endl; // подсчёт времени выполнения программы
    strcpy(str1, "Время сортировки в мс: ");
    CharToOem(str1, buf);
    cout << buf << endl;
    t = (clock() / CLOCKS_PER_SEC) * 60; // функция clock () возвращает время исп программы
    cout << t; // как значение типа clock_t объявленного ранее это // значение можно перевести в секунды
               // поделив на определенную в библиотеке time. h константу CLOCKS_PER_SEC
    getchar();
    getchar();
    return 0;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2018, 07:31
Помогаю со студенческими работами здесь

Сортировка двумерного массива методом вставок по строкам
Помогите, пожалуйста, переделать код для двумерного массива. Думаю, что надо по сути надо добавить цикл, но не могу реализовать. ...

Сортировка массива по убыванию элементов методом вставок
Отсортировать массив по убыванию элементов простыми вставками. Код неправильный, исправьте, если можно с комментарием. #include...

Шаблонная функция: сортировка одномерного массива методом вставок
Написать шаблонную функцию, выполняет сортировку одномерного массива методом вставок. Протестировать работоспособность функции.

Выполнить сортировку одномерного массива X(100) методом бинарных вставок
Здравствуйте уважаемые пользователи форума, прошу составить программу в с++ просто нужно сдать программу эту через 2 дня

Сортировка пузырьковым методом
На вход подается некоторое количество описаний книг (автор, название, количество страниц). Отсортировать и вывести в алфавитном порядке по...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru