Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Reverse iteration from a given map iterator

Tags:

c++

map

stl

I want to find an element in the map using map::find(key), and then iterate the map in reverse order from the point where I found the element, till the beginning (i.e. until map::rend()).

However, I get a compile error when I try to assign my iterator to a reverse_iterator. How do I solve this?

like image 834
OverTheEdge Avatar asked Dec 17 '22 02:12

OverTheEdge


2 Answers

Converting an iterator to a reverse iterator via the constructor should work fine, e.g. std::map<K, V>::reverse_iterator rit(mypos).

A minimal example using std::vector:

#include <vector>
#include <iostream>
#include <algorithm>

int main() {
  typedef std::vector<int> intVec;
  intVec vec;
  for(int i = 0; i < 20; ++i) vec.push_back(i);

  for(intVec::reverse_iterator it(std::find(vec.begin(), vec.end(), 10));
      it != vec.rend(); it++)
    std::cout << *it;
}
like image 186
pmr Avatar answered Dec 24 '22 00:12

pmr


Make the conversion explicit:

std::map<int, int> SomeMap;

for ( int i = 0; i < 10; i++)
    SomeMap[ i ] = i;

std::map<int, int>::iterator it = SomeMap.find( 5 );
std::map<int, int>::reverse_iterator itr( it );

for ( itr; itr != SomeMap.rend( ); itr++ )
    std::cout << itr->first << std::endl;
like image 40
Björn Pollex Avatar answered Dec 24 '22 01:12

Björn Pollex