Accessing map value by index

前端 未结 6 2042
时光取名叫无心
时光取名叫无心 2020-12-01 14:34

If I have a structure like

std::map myMap;
myMap[\"banana\"] = 1;
myMap[\"apple\"] = 1;
myMap[\"orange\"] = 1;

How can I

相关标签:
6条回答
  • 2020-12-01 14:54

    There may be an implementation specific (non-portable) method to achieve your goal, but not one that is portable.

    In general, the std::map is implemented as a type of binary tree, usually sorted by key. The definition of the first element differs depending on the ordering. Also, in your definition, is element[0] the node at the top of the tree or the left-most leaf node?

    Many binary trees are implemented as linked lists. Most linked lists cannot be directly accessed like an array, because to find element 5, you have to follow the links. This is by definition.

    You can resolve your issue by using both a std::vector and a std::map:

    1. Allocate the object from dynamic memory.
    2. Store the pointer, along with the key, into the std::map.
    3. Store the pointer in the std::vector at the position you want it at.

    The std::map will allow an efficient method to access the object by key.
    The std::vector will allow an efficient method to access the object by index. Storing pointers allows for only one instance of the object instead of having to maintain multiple copies.

    0 讨论(0)
  • 2020-12-01 14:55

    Your map is not supposed to be accessed that way, it's indexed by keys not by positions. A map iterator is bidirectional, just like a list, so the function you are using is no more inefficient than accessing a list by position. Your function could be written with help from std::advance( iter, index ) starting from begin(). If you want random access by position then use a vector or a deque.

    0 讨论(0)
  • 2020-12-01 14:56

    Well, actually you can't. The way you found is very unefficient, it have a computational complexity of O(n) (n operations worst case, where n is the number of elements in a map).

    Accessing an item in a vector or in an array have complexity O(1) by comparison (constant computational complexity, a single operation).

    Consider that map is internally implemented as a red black tree (or avl tree, it depends on the implementation) and every insert, delete and lookup operation are O(log n) worst case (it requires logarithm in base 2 operations to find an element in the tree), that is quite good.

    A way you can deal with is to use a custom class that have inside both a vector and a map. Insertion at the end of the class will be averaged O(1), lookup by name will be O(log n), lookup by index will be O(1) but in this case, removal operation will be O(n).

    0 讨论(0)
  • 2020-12-01 14:56

    you can use some other map like containers .
    keep a size fields can make binary search tree easy to random access .
    here is my implementation ...
    std style , random access iterator ...
    size balanced tree ...
    https://github.com/mm304321141/zzz_lib/blob/master/sbtree.h
    and B+tree ...
    https://github.com/mm304321141/zzz_lib/blob/master/bpptree.h

    0 讨论(0)
  • 2020-12-01 14:57

    std::map is an ordered container, but it's iterators don't support random access, but rather bidirectional access. Therefore, you can only access the nth element by navigating all its prior elements. A shorter alternative to your example is using the standard iterator library:

     std::pair<const std::string, int> &nth_element = *std::next(myMap.begin(), N);
    

    This has linear complexity, which is not ideal if you plan to frequently access this way in large maps.

    An alternative is to use an ordered container that supports random access. For example, boost::container::flat_map provides a member function nth which allows you exactly what you are looking for.

    0 讨论(0)
  • 2020-12-01 15:11

    Previous answer (see comment): How about just myMap.begin();

    You could implement a random-access map by using a vector backing-store, which is essentially a vector of pairs. You of course lose all the benefits of the standard library map at that point.

    0 讨论(0)
提交回复
热议问题