Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
krazyd
16 / 0 / 2
Регистрация: 10.11.2012
Сообщений: 115
#1

Использование итераторов

29.06.2016, 17:35. Просмотров 181. Ответов 3
Метки нет (Все метки)

Добрый день, форум!

Слышал что вместо того чтобы писать несколько перегрузок для функции, которая принимает массив или вектор или како-либо еще контейнер, удобно использовать шаблонную функцию с итераторами.

Не подкините примерчик? Или это я может что-то не так понял.

Заранее спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.06.2016, 17:35
Ответы с готовыми решениями:

Использование потоковых итераторов
Вот код:#include<iostream> #include<vector> #include<algorithm>...

Конфликт итераторов
Доброго времени суток. Пишу Timsort с использованием шаблонов и итераторов....

Применение итераторов
Подскажите пожалуйста, в чем практичность итераторов, то бишь для чего нужны...

Перегрузка итераторов
Почему переполняется итератор vector<char>::iterator p = v.begin(); вот код :...

Итерации итераторов С++
Задача "каждому эл-ту вектора присвоить значение его индекса, скопировать это...

3
redseven
56 / 15 / 26
Регистрация: 07.02.2015
Сообщений: 328
29.06.2016, 17:55 #2
Может поможет.

Вот один из примеров неоптимизированного итератора,найден в интернете.

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
71
72
73
74
75
76
77
78
#include <iostream>
#include <iterator>
#include <algorithm>
using namespace std;
 
// T - тип объекта, содержащего элементы
// Tval - тип элементов
template <typename T,typename Tval>
class It2d: public std::iterator
     <std::forward_iterator_tag, T> {
protected:
T& datab;   // объект с элементами, и с операцией[]
int posbeg; // с какого элемента
int width;  // полная ширина
int w;      // ширина окна
int i;      // текущая позиция
 
public:
It2d(T& ddatab, int pposbeg, int wwidth,
     int ww, int pos=0): datab(ddatab){
width=wwidth;
w=ww;
posbeg=pposbeg;
i=pos;
}
 
 
It2d(const It2d<T,Tval>& a):datab(a.datab){
width=a.width;
w=a.w;
i=a.i;
posbeg=a.posbeg;
}
 
//----------------------------------
Tval& operator *(){
    return datab[posbeg+i%w+i/w*width];
    }
 
It2d<T,Tval>&operator ++(){
    ++i;
    return *this;
    }
 
It2d<T,Tval>& operator ++(int a){
    ++i;
    return *this;
    }
 
bool operator ==(It2d<T,Tval> &it){
return datab==it.datab && i==it.i &&
       w==it.w && width==it.width;
}
 
bool operator !=(It2d<T,Tval>&it){
    return !(*this==it);
    }
};
 
void out(int*data){
for(int i=0;i<10;i++){
  for(int j=0;j<10;j++)
    cout<<data[j+i*10];
cout<<endl;
}
}
 
int main(){
int *data=new int[10*10];
std::fill(data,data+100,1);
out(data);
It2d<int*,int> begin(data,10*2+2,10,3);
It2d<int*,int> end(data,10*2+2,10,3,9);
std::fill(begin,end,2);
cout<<"=========="<<endl;
out(data);
return 0;
}
0
DrOffset
7782 / 4601 / 1117
Регистрация: 30.01.2014
Сообщений: 7,499
29.06.2016, 18:11 #3
Цитата Сообщение от krazyd Посмотреть сообщение
Слышал что вместо того чтобы писать несколько перегрузок для функции, которая принимает массив или вектор или како-либо еще контейнер, удобно использовать шаблонную функцию с итераторами.
Не подкините примерчик?
Кликните здесь для просмотра всего текста

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
#include <iostream>
#include <vector>
#include <list>
 
template <typename Iterator>
void print_container(Iterator start, Iterator finish)
{
    while(start != finish)
    {
        std::cout << *start++ << ' ';
    }
    std::cout << std::endl;
}
 
int main()
{
    int array[] = {1,2,3,4};
    
 
    std::vector<double> vec;
    vec.push_back(4);
    vec.push_back(5);
    vec.push_back(6);
    
 
    std::list<char> list;
    list.push_back('A');
    list.push_back('B');
    list.push_back('C');
    
    
    print_container(std::begin(array), std::end(array));
    print_container(std::begin(vec), std::end(vec));   // print_container(vec.begin(), vec.end());
    print_container(std::begin(list), std::end(list)); // print_container(list.begin(), list.end());
}
http://rextester.com/TEJHK91389
0
IGPIGP
Комп_Оратор)
Эксперт по математике/физике
7045 / 3346 / 452
Регистрация: 04.12.2011
Сообщений: 9,304
Записей в блоге: 5
29.06.2016, 18:16 #4
del.
Пока сочинял уже написали примеров получше.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.06.2016, 18:16

Не видит класс итераторов
Предметная область: Множество натуральных чисел, Реализованное через Хеш...

Равенство пустых итераторов
Гарантировано ли для стандартных контейнеров равенство пустых итераторов?...

Потоки и запоминание итераторов
Жду помощи... хочу, чтобы 2 потока запоминали итераторы, чтобы потом можно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru