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

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

Войти
Регистрация
Восстановить пароль
 
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 233
#1

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

22.12.2013, 18:01. Просмотров 274. Ответов 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
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++
задан текст нужно вывести на экран количество слов где первая и последняя буквы одинаковы #include &lt;iostream&gt; #include &lt;conio.h&gt; ...

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

Ошибка при компиляции. Где ошибка? (Работа с классом) - C++
Уважаемые форумчане! При компиляции проекта возникает ошибка &quot; undefined reference to `MeterNZiF::MeterNZiF()' &quot; на 7 строку приложения. ...

Укажите где ошибка (ошибка во время выполнения программы) - C++
Здравствуйте, помогите пожалуйста найти ошибки в коде которые возникаю при выполнении программы Картинка с ошибкой внизу поста. Код: ...

В чём ошибка.В коде там где коментарий там ошибка поучается. - C++
#include &lt;iostream&gt; #include &lt;Windows.h&gt; using namespace std; class CMyString{ char *pStr; public: ...

Где ошибка? - C++
#include &lt;iostream&gt; #include &lt;cstdio&gt; #include &lt;string&gt; #include &lt;conio.h&gt; #include &lt;ctype.h&gt; using namespace std; int main() ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 233
23.12.2013, 02:34  [ТС] #2
Товарищи, помогите!!!!!

Добавлено через 6 часов 47 минут
хотябы из-за чего он вписывает число "-842150451" в массив после сортировки?
SatanaXIII
Супер-модератор
Эксперт С++
5609 / 2643 / 244
Регистрация: 01.11.2011
Сообщений: 6,502
Завершенные тесты: 1
23.12.2013, 10:29 #3
Цитата Сообщение от Nike Jagger Посмотреть сообщение
хотябы из-за чего он вписывает число "-842150451" в массив после сортировки?
Где-то вы выходите за границы массива и хапаете там мусор. Скорее всего в HeapSort или в DownHeap в циклах при взятии индекса делением массива пополам. С четным количеством элементов массива проблема не уходит?
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 233
23.12.2013, 13:58  [ТС] #4
Цитата Сообщение от SatanaXIII Посмотреть сообщение
С четным количеством элементов массива проблема не уходит?
нет, не уходит
zss
Модератор
Эксперт С++
6359 / 5923 / 1920
Регистрация: 18.12.2011
Сообщений: 15,226
Завершенные тесты: 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
Сообщений: 233
23.12.2013, 14:45  [ТС] #6
zss, в массив _arr я записываю элементы с четным индексом, соответственно он и должен быть n / 2.

Добавлено через 21 минуту
ошибка в том, что я не правильно записываю четные элементы из одного массива в другой.
zss
Модератор
Эксперт С++
6359 / 5923 / 1920
Регистрация: 18.12.2011
Сообщений: 15,226
Завершенные тесты: 1
23.12.2013, 14:58 #7
Цитата Сообщение от Nike Jagger Посмотреть сообщение
с четным индексом,
Но пишете их в i-е место, а не в i/2 - е.
Вот и вылезаете за границы массива,
который, кстати, оказывается заполненным через один.
Nike Jagger
37 / 37 / 0
Регистрация: 08.03.2012
Сообщений: 233
23.12.2013, 15:00  [ТС] #8
zss, спасибо, я уже понял и исправил)
все работает.
Спасибо всем кто читал весь этот мой идиотизм)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.12.2013, 15:00
Привет! Вот еще темы с ответами:

Где ошибка? - C++
#include&lt;conio.h&gt; #include&lt;iostream.h&gt; #include&lt;fstream.h&gt; #include&lt;stdio.h&gt; #define i 10 int x; char...

Где ошибка? - C++
Компилятор ругается и очень больно #include &quot;stdafx.h&quot; #include&lt;stdio.h&gt; #include&lt;math.h&gt; int _tmain(int argc, _TCHAR* argv) ...

Где ошибка ? - C++
Даны числа x и n . Вычислить S=sin(x)+sin(sin(x))+.....+sin(sin....sin(x)). n Моя...

Где ошибка? - C++
Программа не моя,но нужно запустить ее и показать что она работает. Но в том то и проблема что не запускается) помогите определить где...


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

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

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