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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ решение судоку http://www.cyberforum.ru/cpp-beginners/thread36819.html
Судоку размера n называется квадрат со стороной n2, разделенный на n2 средних квадратов со стороной n, каждый из которых разделен на n2 маленьких квадратов. В каждом маленьком квадрате записано число...
C++ Создание строк Строка символов представляет собой предложение, написанное на русском языке. Предложение заканчивается точкой. Подсчитать и вывести количество различных букв, которые входят в это предложение. Ответ... http://www.cyberforum.ru/cpp-beginners/thread36802.html
программка с динамическими массивами C++
1. Ввести размер массива; 2.Сформировать массив с помощью операции new или библиотечных функций malloc (calloc); 3.Заполнить массив (можно с помощью датчика случайных чисел); 4.Выполнить задание...
C++ Перегрузка функций в Си++
Задачка легкая...но я вообще никак не дружу с си. Написать перегруженные функции и основную программу, которая их вызывает. а) для сложения десятичных дробей; б) для сложения обыкновенных дробей.
C++ Минимальный элемент массива http://www.cyberforum.ru/cpp-beginners/thread36770.html
Напишите кто может , как после ввода элементов массива найти минимальный элемент этого массива , без использования функции min.
C++ Односвязанные и двух-связанные списки Должны быть следующие функции: 1) Ввод количества элементов и заполнение списка случайными значениями 2) Вывод списка на экран 3) сортировка списка. 4) Добавление элемента в конец списка 5) Удаление... подробнее

Показать сообщение отдельно
Rififi
2360 / 1053 / 44
Регистрация: 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;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru