Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Поменять в строке несколько символов на один символ https://www.cyberforum.ru/ cpp-beginners/ thread1429939.html
Здравствуйте. Нужно поменять в строке несколько символов на один символ. #include <iostream> #include <string.h> #include <fstream> using namespace std; int main() {
Перегрузка операторов C++
"Создать класс - координаты с унарным ++ и --, -. ++ и -- постфиксная и префиксная. - меняет знак у обеих координат. ++ как функция-член, -- как дружественная функция. Создать класс матриц, содержащий ссылку на unsigned char, число строк и столбцов. Определить конструкторы по умолчанию, конструктор с одним и с двумя параметрами, конструктор копирования, деструктор. Определить операторы =, +,...
C++ Насколько целесообразно разбивать программу на несколько функций? Такой вот вопрос. Допустим, программу можно разбить на отдельные функции. С одной стороны это удобно - в одном месте вызываем соответствующую функцию, которая, например, пишет данные в массив. В другом месте -ф-я считывания из массива в поток вывода с некой обработкой. Т.е. каждая функция будет представлять логическое звено всей программы. А с другой стороны - нагрузка на стек, если можно так... https://www.cyberforum.ru/ cpp-beginners/ thread1429932.html C++ Переписать из паскаля https://www.cyberforum.ru/ cpp-beginners/ thread1429927.html
Здравствуйте помогите пожалуйста переписать на с++:) var a,b:array of integer; n,i,c,d,mind:integer; begin read(n); for i:=1 to n do read(a); for i:=1 to n do read(b);
C++ Запись цикла for
как записать в c++ for c:=-1000 to 1000 do Правильно for (int c=-1000; c<1000 ; i++) Заранее спасибо.
C++ Многократный диалог с пользователем Помогите пожалуйста,нужно с помощью функции организовать многократный диалог с пользователем о повторении программы,вот программу написал,а функцию не знаю как. #include <iostream> using namespace std; int main () { setlocale(LC_ALL, "Russian"); int N; cout<<"Введите N"<<endl; cin>>N; https://www.cyberforum.ru/ cpp-beginners/ thread1429896.html
C++ Написать функцию подсчета размера каталога Помогите написать программу написать функцию подсчета размера каталога(найти все папки и подпапки и посчитать их все) https://www.cyberforum.ru/ cpp-beginners/ thread1429894.html C++ Преобразовать исходный текст в текст с выровненными краями
Дан текстовый файл in.txt, содержащий произвольный текст. Получить файл out.txt, содержащий исходный текст с выровненными краями. Выравнивание производить за счет равномерной вставки пробелов в более короткие строки. Вот код который написал, не знаю как сделать:"Выравнивание производить за счет равномерной вставки пробелов в более короткие строки." #include <iostream> #include <fstream>...
C++ Укажите на ошибки https://www.cyberforum.ru/ cpp-beginners/ thread1429859.html
#include <iostream> using namespace std; int cmd(int cmd); int cmd() { int command; cout << "Команды: 1 - Информация о системе. 2 - Выйти из системы. " << endl; cin >> command;
C++ Преобразовать программу из структур в классы https://www.cyberforum.ru/ cpp-beginners/ thread1429845.html
Есть код программы с структурой , эту программу нужно выполнить методом классов . Вот само задание. Для текущего семестра в учебной части вуза имеются сведения об изучаемых студентами дисциплинах: шифр дисциплины (4 цифры),дисциплина,шифр кафедры, кафедра,шифр специальности,специальность кол-во часов(на лекции,самостоятельные работы,лаб.работы),вид отчетности ( есть экзамен/нет экзамена)....
Классы Bar и Car, что не так? C++
В общем, сижу и пытаюсь освоить ООП, но тут проблемка Надо создать 2 класса Bus и Car Для Car нужны параметры скорости и марки. Функции: конструктор, дэструктор, функция печати Для Bus нужны параметры скорости и количества колес. Функции: конструктор, дэструктор, функция печати Надо ввести дружескую функцию (friend) в оба класса, которая будет сравнивать их скорости Вот что я смог...
C++ Нахождение корней уравнения https://www.cyberforum.ru/ cpp-beginners/ thread1429831.html
Программа находит все корни уравнения и записывает в динамический массив. #include <stdio.h> #include <math.h> #include <iostream> using namespace std; double f(double x)
Заблокирован
0

Сортировка бинарными вставками - C++ - Ответ 7526919

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

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

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 минут
Хотя, кажется, я понял, в чем здесь ошибка. Бинарный поиск работает корректно только на отсортированном массиве, а сортировка бинарными вставками использует бинарный поиск. Значит, она работает только на отсортированном массиве. Тогда какая польза сортировать отсортированный массив? Для чего это?

Вернуться к обсуждению:
Сортировка бинарными вставками C++
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.04.2015, 22:11
Готовые ответы и решения:

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

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

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

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

1
24.04.2015, 22:11
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
24.04.2015, 22:11
Помогаю со студенческими работами здесь

Сортировка Шелла и сортировка вставками
Напишите программу для: 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...

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