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

Удаление динамического массива - C++

Восстановить пароль Регистрация
 
thejadefalcon
 Аватар для thejadefalcon
0 / 0 / 0
Регистрация: 23.09.2013
Сообщений: 41
14.12.2013, 22:29     Удаление динамического массива #1
Привет. Сделал программу с 3 динамическими массивами, но дело в том, что 2 из них, размер которых задается с клавиатуры, удаляются в конце из памяти, а 3-ий, размер которого формируется в процессе выполнения программы, не удаляется - компилятор указывает на проблему в delete[]C;
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
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
 
void main()
 
{
    int n, x, k;
    int i = 0;
 
    printf("Enter the size of the array A:\n");
    scanf("%d", &n);
    printf("Enter the size of the array B:\n");
    scanf("%d", &x);
    
    // Задание размера и ввод массивов
    int *A = new int[n]; // Выделение памяти для массива
    printf("Enter the elements of array A:\n");
    for (i = 0; i < n; i++)
        scanf("%d", &A[i]);
 
    int *B = new int[x];
    printf("Enter the elements of array B:\n");
    for (i = 0; i < x; i++)
        scanf("%d", &B[i]);
    
    k = 0;
    int *C = new int[k];
        
    // Начало обработки массивов
    for (int i = 1; i < n; i++)
    if ((A[i] % 2 == 0) && (A[i - 1] % 2 != 0)) // Поиск четного элемента в A
    {
        C[k] = A[i];
        for (int j = i; j < n; j++)
            A[j] = A[j + 1];
        n = n - 1;
        k++;
    }
    
    printf("Changed array A: ");
    for (int i = 0; i < n; i++)
        printf("%2d", A[i]);
    printf("\n");
    printf("Resulting array C: ");
    for (int i = 0; i < k; i++)
        printf("%2d", C[i]);
    printf("\n");
    
    // Обработка массива B и C
    int min = B[0];
    for (i = 0; i < x; i++)
        if (B[i] < min)
            min = B[i];
    int max = B[0];
    for (i = 0; i < x; i++)
    if (B[i] > max)
        max = B[i];
    double median = (min + max) / 2;
    double delta = abs(median - min);
    int resID = 0;
    for (i = 0; i < x; i++)
        if (abs(median - B[i]) < delta)
        {
            resID = i;
            delta = abs(median - B[i]);
        }
    C[k] = B[resID];
    
    for (int j = resID; j < x; j++)
        B[j] = B[j + 1];
    x = x - 1;
    
    printf("Changed array B: ");
    for (int i = 0; i < x; i++)
        printf("%2d", B[i]);
    printf("\n");
    printf("Resulting array C: ");
    for (int i = 0; i <= k; i++)
        printf("%2d", C[i]);
    printf("\n");
    
    // Удаление памяти
    delete[]A;
    delete[]B;
    delete[]C;
    
    system("pause");
}
Если избавиться от строчки delete[]C;, программа компилируется и выполняется. В чем дело?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ZeR_0
116 / 108 / 37
Регистрация: 30.01.2013
Сообщений: 297
14.12.2013, 22:33     Удаление динамического массива #2
C++
1
2
 k = 0;
    int *C = new int[k];
thejadefalcon
 Аватар для thejadefalcon
0 / 0 / 0
Регистрация: 23.09.2013
Сообщений: 41
14.12.2013, 22:35  [ТС]     Удаление динамического массива #3
А как исправить?
katsidelin
 Аватар для katsidelin
60 / 21 / 2
Регистрация: 15.11.2013
Сообщений: 112
Записей в блоге: 3
14.12.2013, 22:46     Удаление динамического массива #4
Цитата Сообщение от thejadefalcon Посмотреть сообщение
k = 0; int *C = new int[k];
Пустой указатель нельзя удалять, потому и не компилируется, на сколько я понял.
А во всякие ифы он и не дожен вникать, мало ли увеличится число элементов или нет.
Попробуйте заменить k с нуля на натуральное число и ретранслируйте код.

Добавлено через 6 минут
Цитата Сообщение от thejadefalcon Посмотреть сообщение
k = 0; int *C = new int[k];
Пустой указатель нельзя удалять, потому и не компилируется, на сколько я понял.
А во всякие ифы он и не дожен вникать, мало ли увеличится число элементов или нет.
Попробуйте заменить k с нуля на натуральное число и ретранслируйте код.

Также можно просто:
C++
1
int *C;
Добрый миломан
3 / 3 / 1
Регистрация: 20.06.2013
Сообщений: 35
14.12.2013, 22:49     Удаление динамического массива #5
Цитата Сообщение от thejadefalcon Посмотреть сообщение
k = 0;
int *C = new int[k];
пример из жизни: Начальник сказал подчиненым купить 0 мешков цемента и сказать ему где они находятся Понятное дело что невозможно указать на то, чего нету.
thejadefalcon
 Аватар для thejadefalcon
0 / 0 / 0
Регистрация: 23.09.2013
Сообщений: 41
14.12.2013, 22:49  [ТС]     Удаление динамического массива #6
Спасибо, понял в чем проблема. Сейчас все работает
Yandex
Объявления
14.12.2013, 22:49     Удаление динамического массива
Ответ Создать тему
Опции темы

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