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

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

24.05.2018, 20:30. Показов 945. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru