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

Удаление из масива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread204945.html
Вычислить сколько в строке самых коротких слов.
C++ Возведение в степень Вывести на экран таблицу степеней "к", где те изменяются от 1 до 10,к-вещественое число.оперцию возведения вещественого числа в степень оформить в виде функции http://www.cyberforum.ru/cpp-beginners/thread204923.html
C++ Вычислить среднее арифметическое положительных элементов массива
Из масивов а и в сформировать масив с, записывать в него элементы масивов а и в с чётными индексами. Вычислить среднее арифметическое положительных элементов масива
C++ Найти частное от деления нацело N на K, а также остаток от этого деления
While3. Даны целые положительные числа N и K. Используя только операции сложения и вычитания, найти частное от деления нацело N на K, а также остаток от этого деления. Помогите
C++ Найти сумму элементов тех строк матрицы, которые хотя бы один отрицательный элементсодержат http://www.cyberforum.ru/cpp-beginners/thread204618.html
Помогите написать 3 программы на C++ Заранее спасибо!Надеюсь на вашу помощь..
C++ Запись бинарного дерева в файл и восстановление из него этого дерева Задача такая: есть бинарное дерево. Каждый элемент дерева содержит 3 указателя - 1 указатель на структуру с данными, 2 и 3й указатель на потомков этого элемента - левый и правый. Построение дерева и перебор его элементов осуществлен с помощью рекурсивного метода. Как можно реализовать запись этого дерева в файл, что бы его потом можно было из него восстановить. Тем пересмотрел достаточно, люди... подробнее

Показать сообщение отдельно
xAtom
 Аватар для xAtom
910 / 735 / 60
Регистрация: 09.12.2010
Сообщений: 1,346
Записей в блоге: 1
09.12.2010, 12:25     Удаление из масива
Задача не совсем понятно, под какой массив удаление вы хотите сделать под статический заранее выделенный или динамический - кучевой(heap).

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
//  универсальная функция которая будет рабоать со всеми типами 
// данных к примеру:  char, wchar_t, short, int, long, long int, float, double, long double...N
template<typename T>
void    delete_array(T*  _arr, int _index, int& _size) {
    if(_index == 0 && _size == 1) {
            *_arr = 0;  
            return;
    }
    for(int i = _index; i <  _size - 1; i++)  {
            *((_arr) + i) = *((_arr) + i + 1);
    }
    *((_arr) + _size - 1) = 0;
    _size -= 1;
}
 
 
 
void  main(){
 
 
    //  статический массив  из четырёх элементов
    double  darr[4];
    int   dsize = sizeof(darr) / sizeof(double);   // размер массива
 
    darr[0]    = 23000.77;
    darr[1]   =  3.145674;
    darr[2]   = 450.555;
    darr[3]  = 7.9999;
 
    // мы хотим удалить из массива второй элемент
    ::delete_array(darr, 1, dsize);
 
    const double* p = darr;
    while(dsize-- )
            cout << "element to array = " << *p++ << endl;
 
    // динамический массив контролируемый прграммистом
 
    short* sarr = new short[ 3 ];
    int  ssize = 3;
    sarr[0] = 0xaaa;
    sarr[1] = 0xbbb;
    sarr[2] = 0xccc;
 
    ::delete_array(sarr, 1, ssize);
    ::delete_array(sarr, 1, ssize);
 
    for(int i = 0; i < ssize; i++)
            cout << "short data = " << sarr[i] << endl;
 
    delete[] sarr;
    sarr = NULL;
 
             cin.get();
}
Посмотри, на очень простой пример...

Добавлено через 14 минут
C++
1
2
3
4
5
  if(_index == 0 && _size == 1) {
                        *_arr = 0; 
                        _size= 0;   // здесь нуль надо поставить забыл про завершение массива
                        return;
        }
Если не помог суть задачи не понял значить...
 
Текущее время: 13:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru