Заблокирован
1

Сортировка бинарными вставками

24.04.2015, 22:11. Показов 2333. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Сортировка бинарными вставками работает неправильно. Помогите найти ошибку.
Вот код:

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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
template <class T>
void swap(T& a, T& b){
    T temp(a);
    a = b;
    b = temp;
}
 
//Бинарный поиск
int binsearch(int array[], int key, int size){
    int left = 0;
    int right = size;
    int mid;
 
    if(size == 0) return -1;
 
    while (left <= right){
        mid = left + (right - left) / 2;
        if(key < array[mid])
            right = mid - 1;
        else if(key > array[mid])
            left = mid + 1;
        else return mid;
    }
    return -1;
}
 
//Сортировка бинарными вставками
void binsort(int array[], int size){
    int j, k, m;
    for(int i = 0; i < size; i++){
        j = i - 1;
        k = binsearch(array, array[i], size);
        for(int m = j; m >= k; m--)
            swap(array[m], array[m+1]);
    }
}
 
//Генерация случайной последовательности
void genRandSeq(int *array){
    std::srand(std::time(0));
    for(int i = 0; i < SIZE; i++)
        array[i] = std::rand();
}
 
//Функция main
int main(){
    int seq[SIZE];
    genRandSeq(seq);
 
    binsort(seq, SIZE);
 
    for(int i = 0; i < SIZE; i++)
        std::cout << seq[i] << " ";
    std::cout << std::endl;
 
    int pause;
    std::cin >> pause;
}
Добавлено через 9 минут
Хотя, кажется, я понял, в чем здесь ошибка. Бинарный поиск работает корректно только на отсортированном массиве, а сортировка бинарными вставками использует бинарный поиск. Значит, она работает только на отсортированном массиве. Тогда какая польза сортировать отсортированный массив? Для чего это?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.04.2015, 22:11
Ответы с готовыми решениями:

Сортировка бинарными вставками
Имеется функция сортировки бинарными вставками, нужна программа, в которой она будет...

Сортировка бинарными вставками
Если у кого нибудь есть, выложите рабочий код сортировки бинарными вставками. Просто Си.Буду...

Сортировка списка бинарными вставками
Добрый день. Скажите в чем проблема. Вроде все правильно написано. код пересматривал несколько раз...

Сортировка вектора по полю(Сортировка вставками)
Здравствуйте! Нужно написать сортировку вектора по полю weight класса tomato. Вот класс: #pragma...

1
102 / 102 / 39
Регистрация: 17.04.2011
Сообщений: 554
25.04.2015, 06:54 2
https://ru.wikipedia.org/wiki/... A%E0%EC%E8
0
25.04.2015, 06:54
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.04.2015, 06:54
Помогаю со студенческими работами здесь

Сортировка Шелла и сортировка вставками
Напишите программу для: 1)Сортировка вставкой 2)сортировка Шелла

Сортировка вставками
Добрый день, есть один вопрос #include &quot;stdafx.h&quot; #include&lt;iostream&gt; #include&lt;string&gt;...

Сортировка вставками
#include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;ctime&gt; using namespace std; const int n =...

Сортировка вставками
#include &lt;iostream&gt; #include &lt;ctime&gt; #include &lt;iomanip&gt; using namespace std; void...


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

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

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