Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 04.09.2014
Сообщений: 10

Сравнить сортировку Шелла и сортировку с помощью прямого включения

06.09.2014, 14:03. Показов 1737. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Хотел бы узнать как можно написать код который будет сравнивать сортировку Шелла и сортировка с помощью прямого включения на C++ builder6. Я не могу это сделать потому что не изучал данный язык вообще
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.09.2014, 14:03
Ответы с готовыми решениями:

Выполнить сортировку данных с помощью прямого включения
Разработать программу выполняющую следующие действия: 1.чтение данных(из файли или с клавиатуры); 2.выполнить сортировку данных с...

Упорядочить элементы массива по убыванию, используя сортировку с помощью прямого включения
1. Сформировать одномерный массив с помощью генератора случайных чисел. Вывести элементы исходного массива на экран. Фактическую...

Сравнить пузырьковую сортировку и сортировку Шелла
Я написал програмку нужно сравнить: пузырьковую сортировку и сортировку Шелла, но программа не коректна работает, подскажите где и что...

9
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
06.09.2014, 19:17
Цитата Сообщение от Георгий_1992 Посмотреть сообщение
код который будет сравнивать сортировки Шелла и с помощью прямого включения
Сравнивать на предмет чего?
0
0 / 0 / 0
Регистрация: 04.09.2014
Сообщений: 10
07.09.2014, 09:39  [ТС]
BRcr,Сравнивать по количеству перестановок.
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
07.09.2014, 11:10
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
int increment( long inc[ ], long size )
{
    int p1, p2, p3, s;
    p1 = p2 = p3 = 1;
    s = -1;
    do
    {
        if ( ++s % 2 )
        {
            inc[ s ] = 8 * p1 - 6 * p2 + 1;
        }
        else
        {
            inc[ s ] = 9 * p1 - 9 * p3 + 1;
            p2 *= 2;
            p3 *= 2;
        }
        p1 *= 2;
    }
    while ( 3 * inc[ s ] < size );
 
    return s > 0 ? --s : 0;
}
 
template < class T >
long long shellSort( T a[ ], long size )
{
    long inc, i, j, seq[ 40 ];
    int s;
    long long cnt( 0 );
 
    s = increment( seq, size ); // вычисление последовательности приращений
    while ( s >= 0 ) // сортировка вставками с инкрементами inc[]
    {
        inc = seq[ s-- ];
        for ( i = inc; i < size; ++i )
        {
            T temp = a[ i ];
            for ( j = i - inc; ( j >= 0 ) && ( a[ j ] > temp ); j -= inc )
            {
                a[ j + inc ] = a[ j ];
                ++cnt;
            }
            a[ j ] = temp;
            ++cnt;
        }
    }
    return cnt;
}
 
template < class T >
long long insertSort( T * a, int size )
{
    T tmp;
    long long cnt( 0 );
 
    for ( int i = 1, j; i < size; ++i ) // цикл проходов, i - номер прохода
    {
        tmp = a[ i ];
        for ( j = i - 1; j >= 0 && a[ j ] > tmp; --j )
        { // поиск места элемента в готовой последовательности
            a[ j + 1 ] = a[ j ];
            ++cnt;
        } // сдвигаем элемент направо, пока не дошли
        a[ j + 1 ] = tmp; // место найдено, вставить элемент
        ++cnt;
    }
    return cnt;
}
 
void __fastcall TForm1::btn_rocknrollClick( TObject * Sender )
{
    const int size( 10000 );
    int arr[ size ];
 
    srand( time( 0 ) );
    for ( size_t i( 0 ), i_limit( size ); i < i_limit; ++i )
    {
        arr[ i ] = rand( ) % size;
    }
    ShowMessage( String( "Прямое включение - " ) + insertSort( arr, size ) + " перестановок,\n" +
        "сортировка Шелла - " + shellSort( arr, size ) + " перестановок" );
}
Как видно, количество перестановок варьируется от различий в случайном расположении элементов сгенерированного массива. Оно будет варьироваться еще больше при определенных обстоятельствах - частично отсортированный массив или массив с большим количеством повторяющихся элементов. Экспериментируй.
Миниатюры
Сравнить сортировку Шелла и сортировку с помощью прямого включения   Сравнить сортировку Шелла и сортировку с помощью прямого включения   Сравнить сортировку Шелла и сортировку с помощью прямого включения  

0
0 / 0 / 0
Регистрация: 04.09.2014
Сообщений: 10
08.09.2014, 07:54  [ТС]
BRcr, А ка мне реализовать такой вариант: по нажатию на кнопку формируется массив, по нажаттию на следующую кнопку он сортируется одним методом потом по нажатию на следующую кнопку он сортируется другим и по нажатию на 4 кнопку он показывает сколько переходом было сделано и какая из сортировок была эффективней
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
08.09.2014, 21:54
Пардон, чего-то я тупанул неимоверно. shellSort сортирует уже отсортированный массив...
Попробовал исправить... внезапно заглючила функция сортировки Шелла - непонятных av накидала. Так что взял другую реализацию с википедии.

Вот так будет правильно:
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
template < typename T >
bool comp_ascend( T first, T second )
{
    return first < second;
}
 
template < typename RandomAccessIterator, typename Compare >
long long shell_sort( RandomAccessIterator first, RandomAccessIterator last, Compare comp )
{
    long long cnt( 0 );
    for ( typename std::iterator_traits < RandomAccessIterator > ::difference_type
        d = ( last - first ) / 2; d != 0; d /= 2 )
    {
        for ( RandomAccessIterator i = first + d; i != last; ++i )
        {
            for ( RandomAccessIterator j = i; j - first >= d && comp( *j, *( j - d ) ); j -= d )
            {
                std::swap( * j, * ( j - d ) );
                ++cnt;
            }
        }
    }
    return cnt;
}
 
template < class T >
long long insertSort( T * a, int size )
{
    T tmp;
    long long cnt( 0 );
 
    for ( int i = 1, j; i < size; ++i ) // цикл проходов, i - номер прохода
    {
        tmp = a[ i ];
        for ( j = i - 1; j >= 0 && a[ j ] > tmp; --j )
        { // поиск места элемента в готовой последовательности
            a[ j + 1 ] = a[ j ];
            ++cnt;
        } // сдвигаем элемент направо, пока не дошли
        a[ j + 1 ] = tmp; // место найдено, вставить элемент
        ++cnt;
    }
    return cnt;
}
 
void __fastcall TForm1::btn_rollClick( TObject * Sender )
{
    const int size( 10000 );
    int arr[ size ], arr2[ size ];
 
    srand( time( 0 ) );
    for ( size_t i( 0 ), i_limit( size ); i < i_limit; ++i )
    {
        arr[ i ] = arr2[ i ] = rand( ) % size;
    }
    ShowMessage( String( "Прямое включение - " ) + insertSort( arr, size ) + " перестановок,\n" +
        "сортировка Шелла - " + shell_sort( arr2, arr2 + size, comp_ascend < int > ) + " перестановок" );
}

Цитата Сообщение от Георгий_1992 Посмотреть сообщение
А ка мне реализовать такой вариант
Вынеси в класс формы объявление двух массивов и по счетчику для каждого из методов. В обработчике первой кнопки - заполнение одного массива как душе угодно и копирование его во второй массив. В двух других кнопках - сортировка каждого из массивов своим методом и запоминание счетчиков, в последней кнопке - просто вывод счетчиков. Все это можно почерпнуть из уже приведенного кода.
0
0 / 0 / 0
Регистрация: 04.09.2014
Сообщений: 10
12.09.2014, 12:18  [ТС]
BRcr, Я не смог разобраться как мне прописать код для каждой кнопки для сортировки массива (Шелла и прямого включения). есть только код генерации массива
C++
1
2
3
4
5
6
randomize();            //Изменение начального адреса для random()
n=StrToInt(Edit1->Text);
StringGrid2->ColCount=n;
for(int i=0; i<n; i++) StringGrid2->Cells[i][0] = IntToStr(random(2001));
Form4->Button2->Enabled=true;
Form4->Button4->Enabled=true;
Помоги пожалуйста а то я дуб дубом в С++ а работу для практической выполнить надо.
Миниатюры
Сравнить сортировку Шелла и сортировку с помощью прямого включения  
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
17.09.2014, 21:18
Ну, раз никто не желает... то вот, пожалуйте.
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
template < typename T >
bool comp_ascend( T first, T second )
{
    return first < second;
}
 
template < typename RandomAccessIterator, typename Compare >
long long shell_sort( RandomAccessIterator first, RandomAccessIterator last, Compare comp )
{
    long long cnt( 0 );
    for ( typename std::iterator_traits < RandomAccessIterator > ::difference_type
        d = ( last - first ) / 2; d != 0; d /= 2 )
    {
        for ( RandomAccessIterator i = first + d; i != last; ++i )
        {
            for ( RandomAccessIterator j = i; j - first >= d && comp( *j, *( j - d ) ); j -= d )
            {
                std::swap( * j, * ( j - d ) );
                ++cnt;
            }
        }
    }
    return cnt;
}
 
template < class T >
long long insertSort( T * a, int size )
{
    T tmp;
    long long cnt( 0 );
 
    for ( int i = 1, j; i < size; ++i ) // цикл проходов, i - номер прохода
    {
        tmp = a[ i ];
        for ( j = i - 1; j >= 0 && a[ j ] > tmp; --j )
        { // поиск места элемента в готовой последовательности
            a[ j + 1 ] = a[ j ];
            ++cnt;
        } // сдвигаем элемент направо, пока не дошли
        a[ j + 1 ] = tmp; // место найдено, вставить элемент
        ++cnt;
    }
    return cnt;
}
// ---------------------------------------------------------------------------
class TForm1 : public TForm
{
__published: // IDE-managed Components
    TStringGrid *sgrid_shell_arr;
    TStringGrid *sgrid_insert_arr;
    TButton *btn_sort_shell;
    TButton *btn_sort_insert;
    TEdit *edt_arr_size;
    TButton *btn_generate_arr;
    TMemo *mem_result;
    void __fastcall btn_generate_arrClick(TObject *Sender);
    void __fastcall btn_sort_shellClick(TObject *Sender);
    void __fastcall btn_sort_insertClick(TObject *Sender);
 
public: // User declarations
 
      std::vector< int> vcr_shell_arr, vcr_insert_arr;
    __fastcall TForm1( TComponent * Owner );
     __fastcall ~TForm1( );
} ;
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
__fastcall TForm1::TForm1( TComponent * Owner )
    :
    TForm( Owner )
{
    srand( time( 0 ) );
}
 
// ---------------------------------------------------------------------------
__fastcall TForm1::~TForm1( )
{
 
}
 
// ---------------------------------------------------------------------------
void __fastcall TForm1::btn_generate_arrClick( TObject * Sender )
{
    int size, tmp;
    if ( TryStrToInt( edt_arr_size->Text, size ) )
    {
        vcr_shell_arr.clear( );
        sgrid_shell_arr->Cols[ 0 ]->Clear( );
        sgrid_insert_arr->Cols[ 0 ]->Clear( );
        sgrid_shell_arr->RowCount = size;
        sgrid_insert_arr->RowCount = size;
 
        for ( size_t i( 0 ), i_limit( size ); i < i_limit; ++i )
        {
            tmp = rand( ) % size;
            vcr_shell_arr.push_back( tmp );
            sgrid_shell_arr->Cells[ 0 ][ i ] = IntToStr( tmp );
            sgrid_insert_arr->Cells[ 0 ][ i ] = sgrid_shell_arr->Cells[ 0 ][ i ];
        }
        vcr_insert_arr.resize( vcr_shell_arr.size( ) );
        std::copy( vcr_shell_arr.begin( ), vcr_shell_arr.end( ), vcr_insert_arr.begin( ) );
    }
    else
    {
        ShowMessage( "Некорректный ввод." );
    }
}
 
// ---------------------------------------------------------------------------
void __fastcall TForm1::btn_sort_shellClick( TObject * Sender )
{
    if ( vcr_shell_arr.size( ) )
    {
        mem_result->Lines->Add( String( "сортировка Шелла - " ) +
            shell_sort( vcr_shell_arr.begin( ), vcr_shell_arr.end( ), comp_ascend < int > ) + " перестановок" );
        for ( size_t i( 0 ), i_limit( vcr_shell_arr.size( ) ); i < i_limit; ++i )
        {
            sgrid_shell_arr->Cells[ 0 ][ i ] = IntToStr( vcr_shell_arr[ i ] );
        }
    }
}
 
// ---------------------------------------------------------------------------
void __fastcall TForm1::btn_sort_insertClick( TObject * Sender )
{
    if ( vcr_insert_arr.size( ) )
    {
        mem_result->Lines->Add( String( "Прямое включение - " ) +
            insertSort( & vcr_insert_arr.front( ), vcr_insert_arr.size( ) ) + " перестановок" );
        for ( size_t i( 0 ), i_limit( vcr_insert_arr.size( ) ); i < i_limit; ++i )
        {
            sgrid_insert_arr->Cells[ 0 ][ i ] = IntToStr( vcr_insert_arr[ i ] );
        }
    }
}
Миниатюры
Сравнить сортировку Шелла и сортировку с помощью прямого включения  
Вложения
Тип файла: rar VCL forms test app.rar (35.9 Кб, 9 просмотров)
0
0 / 0 / 0
Регистрация: 04.09.2014
Сообщений: 10
28.09.2014, 11:35  [ТС]
BRcr, Вот уже почти вторую неделю бьюсь не запускает выдаёт ошибку. Вернее много ошибок
Миниатюры
Сравнить сортировку Шелла и сортировку с помощью прямого включения  
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
28.09.2014, 12:11
Не бьёшься, а пальцем небо тыкаешь в лучшем случае. Если б удосужился перевести и понять ошибки, таких нелепых у тебя не было бы.
В общем, начинай биться отсюда - Compiler Errors And Warnings (C++) Index
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.09.2014, 12:11
Помогаю со студенческими работами здесь

Как сделать сортировку массива двумя способами: пузырьковым и методом прямого включения
Ребят кто может помочь разобраться, как сделать сортировку массива 2-мя способами. пузырьковым и методом прямого включения?

Заменить сортировку в программе на сортировку методом Шелла
Добрый день Мне сказали заменить сортировку в моей программе на сортировку методом Шелла т.к. она не рациональная, а как это сделать не...

Выполнить сортировку с помощью прямого обмена и вывести данные и результаты на экран
Здравствуйте. Совсем запутался. 1.Требуется выполнить чтение данных с клавиатуры и из файла с возможностью выбора.2.Выполнить сортировку...

Сортировку вставками меняем на Пирамидальную сортировку и на Сортировку подсчётом
Здравствуйте. Я не как не могу разобраться.Помогите. У меня есть листинг сортировки вставками: #include &quot;stdafx.h&quot; ...

Сравнение методов сортировки массивов: метод прямого включения и Шелла
Задание: Написать учебно-демонстрационную программу, которая сравнивает методы прямого включения и Шелла сортировки массивов.Очень срочно...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru