Форум программистов, компьютерный форум 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 */ #define DL_FIO 25 /* dlina polya familii v fayle */ #define DL_SCHOOL 5 /* dlina polya nomera school */
C++ Добавить элементы в конец, начало, середину односвязного списка http://www.cyberforum.ru/cpp-beginners/thread734603.html
Может у кого есть примеры кода, как добавить элементы в конец, начало, середину односвязного списка.
C++ Создать класс целых чисел Помогите... не знаю как делать их.. ( а) Создать класс целых чисел. Определить операторы "++" и "+", как методы класса, а "- -" и "-" как дружественные функции. Операторы должны позволять осуществления операций, как с переменными данного класса, так и с переменными встроенного целого. b) Создать класс Set – множество целых чисел, используя динамическую память. Определить операторы работы с... подробнее

Показать сообщение отдельно
m1ster
1 / 1 / 0
Регистрация: 21.12.2011
Сообщений: 55
16.12.2012, 23:47     итератора для собственного вектора
помогите пожалуйста сделать итератор для вектора
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];
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru