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

где ошибка? - C++

Восстановить пароль Регистрация
 
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 211
22.12.2013, 18:01     где ошибка? #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
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
84
85
86
87
88
89
90
#include <iostream>
#include <conio.h>
#include <ctime>
using namespace std;
 
void printArr(int arr[], int count)
{
    for(int i = 0; i < count; i++)
    {
        cout << arr[i] << " ";
    }
}
 
//-----------------------------------------------------------------
void DownHeap(int m[], int k, int n) 
{
    int newEl;
    int child;
    newEl = m[k];
 
    while(k <= n/2) 
    { 
        child = 2*k;
 
        if(child < n && m[child] < m[child + 1]) 
            child++;
        if( newEl >= m[child] ) 
            break; 
        m[k] = m[child]; 
        k = child;     
    }
    m[k] = newEl;
}
 
void HeapSort(int m[], int n) 
{
    int i;
    int temp;
    for(i = n / 2 - 1; i >= 0; --i) 
        DownHeap(m, i, n - 1);
    for(i= n - 1; i > 0; --i) 
    {
        temp = m[i]; 
        m[i] = m[0];
        m[0] = temp;
        DownHeap(m, 0, i - 1); 
    }
}
//------------------------------------------------------------------------
int main()
{
    setlocale(LC_ALL,"Russian");
 
    int n;
    int* arr;
    int* _arr;
 
    cout << "Введите размерность массива: " << endl;
    cin >> n;
    cout << "\n";
 
    _arr = new int[n / 2];
    arr = new int[n];
    srand(time(NULL));
    for(int i = 0; i < n; i++)
    {
        arr[i] = rand() % 20 + 1;
    }
 
    cout << "Исходный массив: " << endl;
    printArr(arr, n);
    cout << "\n\n";
 
    for(int i = 0; i < n; i++)
    {
        if(i % 2 == 0) _arr[i] = arr[i];
    }
 
    HeapSort(_arr, n / 2);
 
    for(int i = 0; i < n; i++)
    {
        if(i % 2 == 0) arr[i] = _arr[i];
    }
 
    cout << "Отсортированный массив: " << endl;
    printArr(arr, n);
 
    getch();
}
Но ничего не сортирует, выдает только результат, который во вложениях.
Тем более код сортировки брал готовый. Из-за чего так?
Миниатюры
где ошибка?  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.12.2013, 18:01     где ошибка?
Посмотрите здесь:

C++ Где ошибка?
Где ошибка ? C++
C++ Где ошибка?
Где ошибка? C++
где ошибка ? C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 211
23.12.2013, 02:34  [ТС]     где ошибка? #2
Товарищи, помогите!!!!!

Добавлено через 6 часов 47 минут
хотябы из-за чего он вписывает число "-842150451" в массив после сортировки?
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
23.12.2013, 10:29     где ошибка? #3
Цитата Сообщение от Nike Jagger Посмотреть сообщение
хотябы из-за чего он вписывает число "-842150451" в массив после сортировки?
Где-то вы выходите за границы массива и хапаете там мусор. Скорее всего в HeapSort или в DownHeap в циклах при взятии индекса делением массива пополам. С четным количеством элементов массива проблема не уходит?
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 211
23.12.2013, 13:58  [ТС]     где ошибка? #4
Цитата Сообщение от SatanaXIII Посмотреть сообщение
С четным количеством элементов массива проблема не уходит?
нет, не уходит
zss
Модератор
Эксперт С++
 Аватар для zss
5942 / 5547 / 1783
Регистрация: 18.12.2011
Сообщений: 14,155
Завершенные тесты: 1
23.12.2013, 14:18     где ошибка? #5
Обратите внимание на такие строки
C++
1
2
3
4
 for(int i = 0; i < n; i++)
    {
        if(i % 2 == 0) _arr[i] = arr[i];
    }
а массив _arr у Вас длиной n/2
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 211
23.12.2013, 14:45  [ТС]     где ошибка? #6
zss, в массив _arr я записываю элементы с четным индексом, соответственно он и должен быть n / 2.

Добавлено через 21 минуту
ошибка в том, что я не правильно записываю четные элементы из одного массива в другой.
zss
Модератор
Эксперт С++
 Аватар для zss
5942 / 5547 / 1783
Регистрация: 18.12.2011
Сообщений: 14,155
Завершенные тесты: 1
23.12.2013, 14:58     где ошибка? #7
Цитата Сообщение от Nike Jagger Посмотреть сообщение
с четным индексом,
Но пишете их в i-е место, а не в i/2 - е.
Вот и вылезаете за границы массива,
который, кстати, оказывается заполненным через один.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.12.2013, 15:00     где ошибка?
Еще ссылки по теме:

Где то ошибка C++
C++ Вывести на экран количество слов где первая и последняя буквы одинаковы (не понимаю где ошибка)
C++ Где ошибка?

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

Или воспользуйтесь поиском по форуму:
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 211
23.12.2013, 15:00  [ТС]     где ошибка? #8
zss, спасибо, я уже понял и исправил)
все работает.
Спасибо всем кто читал весь этот мой идиотизм)
Yandex
Объявления
23.12.2013, 15:00     где ошибка?
Ответ Создать тему
Опции темы

Текущее время: 21:56. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru