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

Удаление динамического массива через функцию free - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ сумма номеров максимального и минимального элемента http://www.cyberforum.ru/cpp-beginners/thread277115.html
Задана матрица А, вывести на экран сумму номеров максимального и минимального элементов Добавлено через 1 минуту пробовал сделать, но не могу понять как пронумеровать элементы матрицы, есть такой код #include <conio.h> #include <iostream.h> void main () { clrscr ();
C++ Cреднее арфиметическое элементов дерева Написать функцию для нахождения среднего аримфетического бинарного дерева. int Object::Srednee() { Node* w = this->Root; int kol=0,avg,sum=0; while(w != NULL) { sum+=(int)w->Data; kol++; w=w->Next(); http://www.cyberforum.ru/cpp-beginners/thread277114.html
C++ Найти минимальный и максимальный элемент массива
С++ ребят помогите пожалуйста! Задача: написать на с++ : 1 открыть файл 2 ввести массив х 3 найти мин и макс по массиву х. 4 вывести в файл
Заполнение массива по определенной закономерности C++
Ребят, помогите, пожалуйста заполнить массив вот таким образом a1 a2 a3 ... a(n-2) a(n-1) a(n) a2 a3 a4 ... a(n-1) a(n) a1 a3 a4 a5 ... a(n) a(1) a2 ....................................................
C++ Болты и гайки. http://www.cyberforum.ru/cpp-beginners/thread277085.html
Болты и гайки (Время: 1 сек. Память: 16 Мб Сложность: 17%) Вновь созданная фирма купила заброшенные склады на окраине города. Новому заведующему складами поручили произвести учёт в короткие сроки. Всё шло хорошо, пока случайно не рассыпали контейнеры с болтами и гайками на каждом складе, после чего собрали их в общие (для болтов и гаек) контейнеры, потеряв при этом несколько деталей. ...
C++ лимузин Не могу с помощью класса вывести на экран лимузин.. компилятор выбивает ошибку.. помогите разобраться. #include<conio.h> #include<graphics.h> #include<iostream> using std::cout; using std::cin; #include<stdlib.h> class fun { подробнее

Показать сообщение отдельно
GaDinka
1 / 1 / 0
Регистрация: 01.02.2011
Сообщений: 64
15.04.2011, 19:15     Удаление динамического массива через функцию free
Доброго времени суток! Есть вот такой вопрос: имеется код программы, в которой динамический массив удаляется с помощью операции delete. Необходимо изменить код программы, чтобы удалении происходило с помощью библиотечной функции free.

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
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
 
int size; int *mas; int pos;
 
void _delete(int pos){
    pos--;
    for(int i=pos;i<size-1;i++) mas[i] = mas[i+1];//Сдвигаем элементы массива с нужной позиции влево
    size--;
    mas = (int*)realloc(&mas[0],size*sizeof(int));//Изменяем размер массива
}
 
void add(int pos){
    pos--; size++;
    mas = (int*)realloc(&mas[0],size*sizeof(int));//Увеличиваем размер
    for(int i=size-2;i>=pos;i--) mas[i+1] = mas[i];//Сдвигаем элементы вправо с нужной позиции
    mas[pos] = rand()%30;//Записываем в нужную позицию новый элемент
}
 
void clear(){
    free(&mas[0]);
}
 
void main(){
    scanf("%i",&size);//Считываем размер массива
    mas = (int*)malloc(size*sizeof(int));//Создаем масиив
    srand(time(0));
    for(int i=0;i<size;i++) mas[i] = rand()%30;//Заполняем случайными числами
    for(int i=0;i<size;i++) printf("%i ",mas[i]);//Выводим на экран
    printf("\nNumber to delete: ");
    scanf("%i",&pos);//Считываем индекс элемента для удаления
    _delete(pos);//Удаляем
    for(int i=0;i<size;i++) printf("%i ",mas[i]);//Выводим массив на экран
    printf("\nNumber to add: ");
    scanf("%i",&pos);//Считываем индекс куда добавляем
    add(pos);//Добавляем
    for(int i=0;i<size;i++) printf("%i ",mas[i]);//Выводим на экран
    printf("\n");
    clear();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 19:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru