Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 19, средняя оценка - 4.84
cooller51190555
0 / 0 / 0
Регистрация: 06.05.2011
Сообщений: 34
#1

Сортировка простыми включениями - C++

27.08.2012, 17:40. Просмотров 2550. Ответов 7
Метки нет (Все метки)

Есть массив, его нужно отсортировать простыми включениями(вставками).
У меня получилась вот такая вот программа, но выдаёт не совсем корректную информацию, выдаёт в начале массива 0 и не все элементы выводит.
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
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
 int array[100];
void insertionSort(int *, int); // прототип функции сортировки вставками
 
int main(int argc, char* argv[])
{
    int size_array;
    cout << " Enter length of array"<< endl;
    // считываем количество элементов
    cin >> size_array;
    // считываем элементы массива
    for (int n=1; n<=size_array ; n++) 
    cin >> array[n];
    insertionSort(array, size_array); // вызов функции сортировки вставками
  
    for (int n = 0; n< size_array; n++)
    {
        cout << array[n] << "  "; // печать отсортированного массива
    }
    cout << "\n";
    system("pause");
    return 0;
}
 
void insertionSort(int *arrayPtr, int length) // сортировка вставками
{
    int temp, // временная переменная для хранения значения элемента сортируемого массива
        item; // индекс предыдущего элемента
    for (int counter = 1; counter < length; counter++)
    {
        temp = arrayPtr[counter]; // инициализируем временную переменную текущим значением элемента массива
        item = counter-1; // запоминаем индекс предыдущего элемента массива
        while(item >= 0 && arrayPtr[item] > temp) // пока индекс не равен 0 и предыдущий элемент массива больше текущего
        {
            arrayPtr[item + 1] = arrayPtr[item]; // перестановка элементов массива 
            arrayPtr[item] = temp;
            item--;
        }
    }
}
Помогите решить косяк...
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.08.2012, 17:40
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Сортировка простыми включениями (C++):

Сортировка списка прямыми включениями (вставками) - C++
Ребята кто может помогите с курсовой. Пытаюсь написать класс двунаправленного списка. Проблема возникла с функцией добавления...

Программа с простыми числами - C++
Здравствуйте, мне дали такое условие: &quot;В файле записаны числа. С клавиатуры вводится число. Требуется вывести на экран все простые числа,...

Задача с простыми числами - C++
составить программу нахождения и печати всех простых чисел,меньших заданного числа N.Подсчитать количество простых чисел.Простым называется...

Программа с простыми числами - C++
Помогите кому не сложно написать программу: Задача: Написать программу, которая находит и выводит на экран N первых простых чисел (число...

Программа на С с простыми числами - C++
Пользователь вводит 2 границы диапазона в произвольном порядке. Вывести на экран все простые числа из этого диапазона.

Заполнить массив n*m простыми числами - C++
Здрасьте! Помогите, пожалуйста, с решением задачи :impossible: &quot;Двумерный массив размерности m*n заполнен простыми числами. Найти номера...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
27.08.2012, 18:37 #2
Цитата Сообщение от cooller51190555 Посмотреть сообщение
for (int n=1; n<=size_array ; n++)
Цитата Сообщение от cooller51190555 Посмотреть сообщение
for (int n = 0; n< size_array; n++)
Цитата Сообщение от cooller51190555 Посмотреть сообщение
for (int counter = 1; counter < length; counter++)
cooller51190555, Вы уж как-нибудь определитесь с индексацией: или с 0 начинайте, или с 1.
Например так:
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
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
 int array[100];
void insertionSort(int *, int); // прототип функции сортировки вставками
 
int main(int argc, char* argv[])
{
    int size_array;
    cout << " Enter length of array"<< endl;
    // считываем количество элементов
    cin >> size_array;
    // считываем элементы массива
    for (int n=0; n<size_array ; n++) 
    cin >> array[n];
    insertionSort(array, size_array); // вызов функции сортировки вставками
  
    for (int n = 0; n< size_array; n++)
    {
        cout << array[n] << "  "; // печать отсортированного массива
    }
    cout << "\n";
    system("pause");
    return 0;
}
 
void insertionSort(int *arrayPtr, int length) // сортировка вставками
{
    int temp, // временная переменная для хранения значения элемента сортируемого массива
        item; // индекс предыдущего элемента
    for (int counter = 1; counter < length; counter++)
    {
        temp = arrayPtr[counter]; // инициализируем временную переменную текущим значением элемента массива
        item = counter-1; // запоминаем индекс предыдущего элемента массива
        while(item >= 0 && arrayPtr[item] > temp) // пока индекс не равен 0 и предыдущий элемент массива больше текущего
        {
            arrayPtr[item + 1] = arrayPtr[item]; // перестановка элементов массива 
            arrayPtr[item] = temp;
            item--;
        }
    }
}
edward_jonson
158 / 158 / 25
Регистрация: 23.02.2011
Сообщений: 392
27.08.2012, 18:40 #3
Вводите:
C++
1
for (int n = 1; n <= size_array; n++)
выводите:
C++
1
for (int n = 0; n < size_array; n++)
Это то, что бросается в глаза.
cooller51190555
0 / 0 / 0
Регистрация: 06.05.2011
Сообщений: 34
27.08.2012, 18:55  [ТС] #4
valeriikozlov спасибо за помощь. Если не сложно подскажи как сделать чтоб данные вводить не склавиатуры а уже были определённые.. тоесть не динамически чтоб создавался а заранее выбранный
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
27.08.2012, 19:03 #5
Цитата Сообщение от cooller51190555 Посмотреть сообщение
Если не сложно подскажи как сделать чтоб данные вводить не склавиатуры а уже были определённые.. тоесть не динамически чтоб создавался а заранее выбранный
вот так что-ли нужно?:
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
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
 int array[100];
void insertionSort(int *, int); // прототип функции сортировки вставками
 
int main(int argc, char* argv[])
{
    srand( time( NULL ) );
    int size_array=10;
    //cout << " Enter length of array"<< endl;
    // считываем количество элементов
    //cin >> size_array;
    // считываем элементы массива
    for (int n=0; n<size_array ; n++)
    {
        array[n]=rand()%10;
        cout << array[n] << "  "; // печать неотсортированного массива
 
    }
    cout<<endl;
    insertionSort(array, size_array); // вызов функции сортировки вставками
  
    for (int n = 0; n< size_array; n++)///
    {
        cout << array[n] << "  "; // печать отсортированного массива
    }
    cout << "\n";
    system("pause");
    return 0;
}
 
void insertionSort(int *arrayPtr, int length) // сортировка вставками
{
    int temp, // временная переменная для хранения значения элемента сортируемого массива
        item; // индекс предыдущего элемента
    for (int counter = 1; counter < length; counter++)
    {
        temp = arrayPtr[counter]; // инициализируем временную переменную текущим значением элемента массива
        item = counter-1; // запоминаем индекс предыдущего элемента массива
        while(item >= 0 && arrayPtr[item] > temp) // пока индекс не равен 0 и предыдущий элемент массива больше текущего
        {
            arrayPtr[item + 1] = arrayPtr[item]; // перестановка элементов массива 
            arrayPtr[item] = temp;
            item--;
        }
    }
}
cooller51190555
0 / 0 / 0
Регистрация: 06.05.2011
Сообщений: 34
27.08.2012, 19:08  [ТС] #6
чтоб массив задавался что то типо так:
int array[10]={1, 3, 4 ,5, 27, 2, 54, 1, 0, 15}
Что нужно удалить из кода и что добавить чтоб потом всё нормально выводилось?
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
27.08.2012, 19:11 #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
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
 
void insertionSort(int *, int); // прототип функции сортировки вставками
 
int main(int argc, char* argv[])
{
    //srand( time( NULL ) );
    const int size_array=10;
    int array[size_array]={1,0,4,6,7,2,3,5,7,9};
    //cout << " Enter length of array"<< endl;
    // считываем количество элементов
    //cin >> size_array;
    // считываем элементы массива
    for (int n=0; n<size_array ; n++)
    {
        //array[n]=rand()%10;
        cout << array[n] << "  "; // печать неотсортированного массива
 
    }
    cout<<endl;
    insertionSort(array, size_array); // вызов функции сортировки вставками
  
    for (int n = 0; n< size_array; n++)///
    {
        cout << array[n] << "  "; // печать отсортированного массива
    }
    cout << "\n";
    system("pause");
    return 0;
}
 
void insertionSort(int *arrayPtr, int length) // сортировка вставками
{
    int temp, // временная переменная для хранения значения элемента сортируемого массива
        item; // индекс предыдущего элемента
    for (int counter = 1; counter < length; counter++)
    {
        temp = arrayPtr[counter]; // инициализируем временную переменную текущим значением элемента массива
        item = counter-1; // запоминаем индекс предыдущего элемента массива
        while(item >= 0 && arrayPtr[item] > temp) // пока индекс не равен 0 и предыдущий элемент массива больше текущего
        {
            arrayPtr[item + 1] = arrayPtr[item]; // перестановка элементов массива 
            arrayPtr[item] = temp;
            item--;
        }
    }
}
Thinker
Эксперт C++
4225 / 2199 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
27.08.2012, 19:54 #8
Можно чуточку усовершенствовать алгоритм, записав вот так:
C++
1
2
3
4
5
6
        while(item >= 0 && arrayPtr[item] > temp) 
        {
            arrayPtr[item + 1] = arrayPtr[item]; 
            item--;
        }
        arrayPtr[item + 1] = temp;
К чему лишние присвоения
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.08.2012, 19:54
Привет! Вот еще темы с ответами:

Проверить, являются ли числа простыми - C++
задание Составить программу для проверки утверждения: &quot;Результатами вычислений по формуле x^2+x+41, при 0&lt;x&lt;40 являются простые числа&quot;....

Программирование циклов с простыми переменными - C++
Дорогие форумчане, объясните возможное решение вот этой задачи, я не могу понять вообще смысл нахождения переменной &quot;k&quot;, суммы Z и...

Заполнить массив простыми числами по возрастанию - C++
Нужно заполнить массив из n элементов простыми числами по возрастанию #include&lt;iostream&gt; using namespace std; int main() ...

Заполнить массив из 15 элементов последовательными простыми - C++
Заполнить массив из 15 элементов последовательными простыми


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
27.08.2012, 19:54
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru