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

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

Войти
Регистрация
Восстановить пароль
 
eternalenvy
0 / 0 / 0
Регистрация: 01.07.2014
Сообщений: 27
#1

Не могу удалить динамический массив - C++

05.01.2016, 20:52. Просмотров 244. Ответов 3
Метки нет (Все метки)

В общем, выдает критическую ошибку:
HEAP CORRUPTION DETECTED: after Normal block (#140) at 0x004452BF0.
CRT detected that the application wrote to memory after end of heap buffer.

когда собираюсь удалить из памяти динамический массив. без delete [] все работает. в чем проблема?
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
void fillArray(int *pArray, int size);
void showArray(int *pArray, int size);
void freeArray(int *pArray);
void swap(int *pArray, int size);
 
void showArray(int *pArray, int size) {
    for (int i = 0; i < size; i++) {
        cout << "[" << i + 1 << "]" << ": " << pArray[i] << endl;
    }
    cout << "------------------" << endl;
}
 
void swap(int *pArray, int size) {
    for (int i = 0; i < size; i++) {
        if (pArray[i] % 2 == 0) {
            int temp = pArray[i];
            pArray[i] = pArray[i + 1];
            pArray[i + 1] = temp;
        }
    }
}
 
 
void freeArray(int *pArray) {
    delete [] pArray;
}
 
void fillArray(int *pArray, int size) {
    for (int i = 0; i < size; i++) {
        pArray[i] = 1 + rand() % 50;
    }
}
 
int main() {
    srand(time(0));
    int sizeOfArray = 12;
    int *pArray = new int[sizeOfArray];
    fillArray(pArray, sizeOfArray);
    showArray(pArray, sizeOfArray);
    swap(pArray, sizeOfArray);
    showArray(pArray, sizeOfArray);
    freeArray(pArray);
 
    _getch();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.01.2016, 20:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Не могу удалить динамический массив (C++):

Как удалить динамический массив? - C++
Вот на самом простом запоролся.. int *M; M = new int ; как удалить не помню (

C++ Как удалить динамический массив структур - C++
Как удалить массив структур, который был создан через new? Через deletedata, как заметил не чистится template &lt;typename T1, typename...

Удалить динамический массив в деструкторе класса - C++
Здравствуйте, есть следующий код. Хочу удалить динамический массив в деструкторе, но не выходит, не видит массив. Если описываю массив в...

Удалить нечётные строки двумерного массива (динамический массив) - C++
Требуется написать программу: 1. Удалить все нечётные строки двумерного массива. 2. После той строки, которая содержит наибольший...

Не могу считать матрицу из файла в динамический массив - C++
Вот проблемный кусок программы: fstream f (strConst); if (! f) { cout&lt;&lt;&quot;Error_3&quot;; return 1; } int...

Динамический массив - удалить указанное количество элементов с хвоста массива - C++
Доброе время суток! Ребята, подскажите как реализовать это задание Описать массив указанного пользователем количества элементов. ...

3
Kerry_Jr
Модератор
Эксперт PHP
2201 / 1997 / 700
Регистрация: 14.05.2014
Сообщений: 5,856
Записей в блоге: 1
Завершенные тесты: 5
05.01.2016, 20:57 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
в функции swap строку
Цитата Сообщение от eternalenvy Посмотреть сообщение
C++
1
for (int i = 0; i < size; i++)
заменить на
C++
1
for (int i = 0; i < size-1; i++)
1
olya7
477 / 294 / 91
Регистрация: 18.02.2013
Сообщений: 684
05.01.2016, 20:58 #3
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
надо исправить
C++
1
2
3
4
5
6
7
8
9
void swap(int *pArray, int size) {
    for (int i = 0; i <size-1; i++) {
        if (pArray[i] % 2 == 0) {
            int temp = pArray[i];
            pArray[i] = pArray[i + 1];
            pArray[i + 1] = temp;
        }
    }
}
1
kuza84
-4 / 23 / 4
Регистрация: 25.04.2013
Сообщений: 195
07.01.2016, 06:05 #4
Я чет не допру когда во втором выводе результата по индексу pArray[0] оказывается значение с индекса pArray[size-1] это же получается алгоритм сдвига влево на 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
#include <iostream>
using namespace std;
 
void fillArray(int *pArray, int size);
void showArray(int *pArray, int size);
void freeArray(int *pArray);
void swap(int *pArray, int size);
 
int main ()
{ 
    cout <<"--------------------------------------------------------------------------------";
    cout <<"left shift"<<'\n';
    cout <<"--------------------------------------------------------------------------------";
/*------------------------------------------------------------------------------------------*/    
srand(time(0));
    int sizeOfArray = 12;
    int *pArray = new int[sizeOfArray];
    fillArray(pArray, sizeOfArray);
    showArray(pArray, sizeOfArray);
    swap(pArray, sizeOfArray);
    showArray(pArray, sizeOfArray);
    freeArray(pArray);
/*------------------------------------------------------------------------------------------*/    
    cout <<'\n';
    cout <<"--------------------------------------------------------------------------------";  
    system ("pause"); 
    return 0;
} 
void showArray(int *pArray, int size) {
    for (int i = 0; i < size; i++) {
        cout << "[" << i + 1 << "]" << ": " << pArray[i] << endl;
    }
    cout << "------------------" << endl;
}
 
void swap(int *pArray, int size) {
    for (int i = 0; i < size-1; i++) {
        if (pArray[i] != 0) {
            int temp = pArray[i];
            pArray[i] = pArray[i + 1];
            pArray[i + 1] = temp;
        }
    }
}
 
 
void freeArray(int *pArray) {
    delete [] pArray;
}
 
void fillArray(int *pArray, int size) {
    for (int i = 0; i < size; i++) {
        pArray[i] = 1 + rand() % 50;
    }
}
Добавлено через 8 минут
в цикле for ведь не доходим до последнего индекса массива, толкаем последнее значение из предпоследнего индекса влево, а когда толкаем из 0 индекса в последний ?
C++
1
2
3
4
5
6
7
8
9
void swap(int *pArray, int size) {
    for (int i = 0; i < size-1; i++) {
        if (pArray[i] != 0) {
            int temp = pArray[i];
            pArray[i] = pArray[i + 1];
            pArray[i + 1] = temp;
        }
    }
}
Добавлено через 16 минут
Понял, в процессе работы этого цикла for значение с индекса 0 тащится на size-1 в каждой итерации.
здесь алгоритм сдвига более актуален и интересен чем замены.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.01.2016, 06:05
Привет! Вот еще темы с ответами:

Динамический массив - удалить указанное количество элементов с хвоста массива - C++
Доброе время суток Подскажите, как быть тут? Только на динамический массив перешел Первое задание было: Удалить указанное количество...

Сформировать динамический массив строк; удалить из него строку с заданным номером - C++
Сформировать динамический массив строк. Удалить из него строку с заданным номером. Добавлено через 1 час 15 минут UP!!!

Одномерный динамический массив (удалить все вещественные числа, оставив только целые) - C++
Здравствуйте!Помогите,пожалуйста,надо из динамического массива удалить все вещественные числа, оставив только целые, полу-ченный массив...

Создать двумерный динамический массив и удалить все столбцы в которых присутствует элемент C - C++
#include &lt;cstdlib&gt; #include &quot;stdlib.h&quot; #include &lt;iostream&gt; using namespace std; int n=5; int c=0; int main() { ...


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

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

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