5 / 4 / 0
Регистрация: 09.12.2020
Сообщений: 362
1

Сортировка первой части массива (шейкерной сортировкой)

07.05.2021, 21:27. Показов 1171. Ответов 7

Здраствуйте,форумчане нужно отсортировать первую часть массива(методом шейкером сортировки),буду благодарен помощи,вот то что написал я,не пойму как отсортировать первую часть массива,заранее спасибо)
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
#include <iostream>
#include <fstream> 
#include <clocale>
#include <string>
#include <conio.h>  
using namespace std;
int main()
{
 
    setlocale(LC_CTYPE, "rus");
    int n;
    int c[100];
    cout << "\nEnter the size of array:";
    cin >> n;
    for (int i = 0; i < n; i++) {
        cout << i + 1 << ": ";
        cin >> c[i];
    }
 
    int left = 0, right = n - 1;
    double t;
    int flag = 1;
    while ((left < right) && flag > 0)
    {
        flag = 0;
        for (int i = left; i < right; i++) 
            if (c[i] > c[i + 1])
            {
                t = c[i];
                c[i] = c[i + 1];
                c[i + 1] = t;
                flag = 1;
            }
        right--; 
        for (int i = right; i > left; i--) 
            if (c[i - 1] > c[i])
            {
                t = c[i];
                c[i] = c[i - 1];
                c[i - 1] = t;
                flag = 1;
            }
        left++;
    
    }cout << endl;
    for (int i = 0; i < n; i++) {
        
        cout <<c[i]<<" " ;
        
        
    }
    
    _getch();
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.05.2021, 21:27
Ответы с готовыми решениями:

Шейкерной сортировкой упорядочить массив по возрастанию и по убыванию
Отсортировать заданный массив элементов А по возрастанию и убыванию с помощью метода...

Cоздать ключ с шейкерной сортировкой и 2умя счетчиками (количество подсчетов и количество сравнений)
создать ключ с шейкерной сортировкой и 2умя счетчиками( количество подсчетов и количество сравнений)

Сортировка массива Quick sort(быстрой сортировкой) по возрастанию
МЕТОДЫ СОРТИРОВКИ ДАННЫХ Написать программа по пунктам: 1.Выделение памяти под массив...

Написать программу сортировки массива "быстрой сортировкой" по возрастанию первой цифры числа
Нашла только быструю сортировку по возрастанию чисел. Подскажите, пожалуйста, как реализовать...

7
matviiv
07.05.2021, 21:36
  #2

Не по теме:

АХАХАХ лол,две одинаковие теми просто разние методи сортировки и разние ники,хмммммммм,зачем так делать?На форуме запрещено создавать несколько учетных записей (пользователей-клонов).

0
5 / 4 / 0
Регистрация: 09.12.2020
Сообщений: 362
07.05.2021, 23:07  [ТС] 3
Извините,но вы о чем?
0
427 / 310 / 129
Регистрация: 09.02.2021
Сообщений: 1,094
Записей в блоге: 1
07.05.2021, 23:20 4
Сортировка элементов массива, расположенных за минимальным элементом (методом выбора) ваша ж тема,только з другого аккаунта

Добавлено через 1 минуту
Впервие вижу что два разних человека создают тему с почти одинаковим вопрос,однаковими тегами,стиль кода одинаковий ,ну кароче беспалевно

Добавлено через 4 минуты
Ну типа я могу вам код скинуть но на форуме запрещено создавать несколько учетных записей (пользователей-клонов)
0
5 / 4 / 0
Регистрация: 09.12.2020
Сообщений: 362
07.05.2021, 23:22  [ТС] 5
Если скинете код,могу слово дать что больше вы такого не увидете
1
427 / 310 / 129
Регистрация: 09.02.2021
Сообщений: 1,094
Записей в блоге: 1
07.05.2021, 23:28 6
Лучший ответ Сообщение было отмечено Nickname1244 как решение

Решение

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
#include <iostream>
#include <fstream>
#include <clocale>
#include <string>
#include <conio.h>
using namespace std;
int main()
{
 
    setlocale(LC_CTYPE, "rus");
    int n;
    int c[100];
    cout << "\nEnter the size of array:";
    cin >> n;
    for (int i = 0; i < n; i++) {
        cout << i + 1 << ": ";
        cin >>c[i];
    }
 
    int left = 0, right = n - 1;
    double t;
    int flag = 1;
    while ((left < right) && flag > 0)
    {
        flag = 0;
        for (int i = left; i < right/2; i++)
            if (c[i] > c[i + 1])
            {
                t = c[i];
                c[i] = c[i + 1];
                c[i + 1] = t;
                flag = 1;
            }
        right--;
        for (int i = right/2; i > left; i--)
            if (c[i - 1] > c[i])
            {
                t = c[i];
                c[i] = c[i - 1];
                c[i - 1] = t;
                flag = 1;
            }
        left++;
 
    }cout << endl;
    for (int i = 0; i < n; i++) {
 
        cout << c[i] << " ";
 
 
    }
 
    _getch();
}
Добавлено через 35 секунд
Проверяйте

Добавлено через 35 секунд
Nickname1244, если б з етого аккаунта 2 сообщения сделали то все окКод хотяби есть
0
5 / 4 / 0
Регистрация: 09.12.2020
Сообщений: 362
07.05.2021, 23:34  [ТС] 7
Да,все работает,если не составит труда помогите с заданием на том акке,я его вообще удалю)
0
427 / 310 / 129
Регистрация: 09.02.2021
Сообщений: 1,094
Записей в блоге: 1
07.05.2021, 23:45 8
Nickname1244, ок
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.05.2021, 23:45
Помогаю со студенческими работами здесь

Выполнить сортировку произвольного массива из 10 элементов пузырьковой сортировкой и сортировкой вставками
Выполнить сортировку произвольного массива из 10 элементов пузырьковой сортировкой и сортировкой...

Вычислить среднеквадратичное значение каждых третьих элементов первой части массива
я вообще в этом ничего не понимаю( Вычислить среднеквадратичное значение каждых третьих элементов...

Сортировка массива , передавая части массива в несколько потоков
Помогите понять как работает эта программа class ProducerConsumer&lt;T&gt; : IDisposable { ...

Выполнить сортировку первой половины методом прямого включения, а вторую - методом шейкерной сортировки
дан массив длинной 2к. выполнить сортировку первой половины методом прямого включения, а вторую -...

Сортировка части массива
Напишите программу, которая выполняет сортировку части массива, начиная с элемента с номером K и...

Сортировка части массива
Отсортировать первую треть массива по возрастанию.


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru