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

код реализации класса вектор - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ решение судоку http://www.cyberforum.ru/cpp-beginners/thread36819.html
Судоку размера n называется квадрат со стороной n2, разделенный на n2 средних квадратов со стороной n, каждый из которых разделен на n2 маленьких квадратов. В каждом маленьком квадрате записано число от 1 до n2. Судоку называется правильным, если в каждом столбце, каждой строке и каждом среднем квадрате встречаются все числа от 1 до n2. Недавно Вася нарисовал Судоку размера n. Ваша задача –...
C++ программка с динамическими массивами 1. Ввести размер массива; 2.Сформировать массив с помощью операции new или библиотечных функций malloc (calloc); 3.Заполнить массив (можно с помощью датчика случайных чисел); 4.Выполнить задание варианта, сформировать новый массив(ы)-результат(ы); 5.Напечатать массив(ы)-результат(ы); 6.Удалить динамические массивы с помощью операции delete или библиотечной функции free. Сформировать... http://www.cyberforum.ru/cpp-beginners/thread36795.html
C++ Перегрузка функций в Си++
Задачка легкая...но я вообще никак не дружу с си. Написать перегруженные функции и основную программу, которая их вызывает. а) для сложения десятичных дробей; б) для сложения обыкновенных дробей.
C++ Минимальный элемент массива
Напишите кто может , как после ввода элементов массива найти минимальный элемент этого массива , без использования функции min.
C++ Односвязанные и двух-связанные списки http://www.cyberforum.ru/cpp-beginners/thread36758.html
Должны быть следующие функции: 1) Ввод количества элементов и заполнение списка случайными значениями 2) Вывод списка на экран 3) сортировка списка. 4) Добавление элемента в конец списка 5) Удаление элемента с заданным значением 6) Обмен между элементами. Сравнить скорость сортировки односвязного списка, двух-связного списка и массива. Для сравнения времени выполнения можно использовать функцию...
C++ Как вытащить массив структур? Вот собственно код: struct CandyBar { char name; float weight; int colorie; }; подробнее

Показать сообщение отдельно
Rififi
 Аватар для Rififi
2332 / 1047 / 43
Регистрация: 03.05.2009
Сообщений: 2,656
27.05.2009, 21:40     код реализации класса вектор
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
#include <stdexcept>
 
template <typename T>
class Vec
{
public:
    typedef T* iterator;
    typedef const T& const_reference;
 
    Vec() : begin_(NULL), end_(NULL), last_(NULL)
    {
    }
 
    iterator push_back(const_reference _R)
    {
        if (!begin_)
        {
            begin_ = new T[1];
            end_ = last_ = begin_ + 1;
            *begin_ = _R;
            return begin_;
        }
        
        if (end_ == last_)
        {
            throw std::exception("Увеличение размера вектора недоступно в демонстрационной версии");
        }
        *end_ = _R;
        end_++;
        return end_-1;
    }
 
    void clear() { throw std::exception("Очистка вектора недоступна в демонстрационной версии"); }
 
    iterator begin() { return begin_; }
    iterator end() { return end_; }
 
private:
    iterator        begin_;
    iterator        end_;
    iterator        last_;
};
 
 
int main()
{
    Vec<int> v;
    v.push_back(1);
    return 0;
}
 
Текущее время: 10:05. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru