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

итератора для собственного вектора - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дан проходной лабиринт с одним входом и выходом. Найти кратчайший путь для прохождения этого лабиринта http://www.cyberforum.ru/cpp-beginners/thread734650.html
Дан проходной лабиринт с одним входом и выходом. Найти кратчайший путь для прохождения этого лабиринта.
C++ Определить максимальное значение среди элементов матрицы # include <iostream.h> # include <stdlib.h> # include <conio.h> #define n 5 #define m 7 void vvid (int matr) { int i,j; randomize(); for(i=0;i<n;i++) http://www.cyberforum.ru/cpp-beginners/thread734615.html
C++ Дан одномерный массив из г10 чисел определить номер первого из встретившихся элементов, значение которого равно 0
Помогите составить блок схему, пожалуйста.
C++ Работа с файлами
Помогите исправить код, никак не могу,неправильно выводит победителя #include <stdio.h> #include <string.h> #include <conio.h> #include <stdlib.h> #define DL_NUM 3 /* nomer uchastnica */...
C++ Добавить элементы в конец, начало, середину односвязного списка http://www.cyberforum.ru/cpp-beginners/thread734603.html
Может у кого есть примеры кода, как добавить элементы в конец, начало, середину односвязного списка.
C++ Создать класс целых чисел Помогите... не знаю как делать их.. ( а) Создать класс целых чисел. Определить операторы "++" и "+", как методы класса, а "- -" и "-" как дружественные функции. Операторы должны позволять... подробнее

Показать сообщение отдельно
m1ster
1 / 1 / 0
Регистрация: 21.12.2011
Сообщений: 55

итератора для собственного вектора - C++

16.12.2012, 23:47. Просмотров 515. Ответов 5
Метки (Все метки)

помогите пожалуйста сделать итератор для вектора
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
template <class T>
class myvector
{
private:
    int top;//сколько элементов в векторе
    T* arr;
    int sz;//максимальное количество элементов в векторе
public:
    myvector(int=0);//конструктор по умолчанию
    void push_back(const T&);//добавление в конец вектора
    void erase(const T&);
    myvector(const myvector<T>&);//копирующий конструктор
    ~myvector(){delete [] arr;}//диструктор
    myvector<T>&operator=(const myvector<T>&);//оператор присваивания
    T& operator [](int);//оператор для элементов вектора
    const int size();//функция возвращения количества элементов
};
template<class T>
const int myvector<T>::size()
{
    return top;
}
template <class T>
void myvector<T>::push_back(const T&el)
{
    //if(top<sz)
    arr[top++]=el;//в конец записываем элемент
}
template <class T>
void myvector<T>::erase(const T&el)
{
    for(int i=0;i<top;++i)
    if(arr[i]==el)
    {
        for(i;i<top;++i){
            arr[i]=arr[i+1];
        }
    }
    top--;
}
template <class T>
myvector<T>::myvector(int n):top(0)
{
    sz=n>0 ? n : 100;//если n>0 то принимаем значение n если нет то n=100;
    arr=new T[sz];
}
template <class T>
myvector<T>::myvector(const myvector<T>&s):top(s.top),sz(s.sz),arr(new T[s.sz])
{
    for(int i=0; i<top;++i)
        arr[i]=s.arr[i];
}
template <class T>
myvector<T>&myvector<T>::operator=(const myvector<T>&s)
{
    if(this!=&s){
        delete [] arr;
        top=s.top;
        sz=s.sz;
        arr=new T[sz];
        for(int i=0;i<top;++i)
            arr[i]=s.arr[i];
}
    return *this;
}
template <class  T>
T& myvector<T>::operator[](int i)
{
    return arr[i];
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru