ペアのベクトルがあります。ペアの最初のタイプはstd :: string型で、2番目のタイプはContainerタイプです。
文字列値をキーとして指定してコンテナを返すことができるように、stdまたはboostにはどのような便利な機能がありますか?
[〜#〜] update [〜#〜]
代わりにstd :: mapを使用できるとコメントされていますが、実際には、アイテムをベクターにプッシュする順序で、アイテムの順序を保持する必要があります。
考えられる解決策:
struct comp
{
comp(std::string const& s) : _s(s) { }
bool operator () (std::pair<std::string, Container> const& p)
{
return (p.first == _s);
}
std::string _s;
};
// ...
typedef std::vector<std::pair<std::string, Container> > my_vector;
my_vector v;
// ...
my_vector::iterator i = std::find_if(v.begin(), v.end(), comp("World"));
if (i != v.end())
{
Container& c = i->second;
}
// ...
完全な例を次に示します。
#include <vector>
#include <utility>
#include <string>
#include <algorithm>
struct Container
{
Container(int c) : _c(c) { }
int _c;
};
struct comp
{
comp(std::string const& s) : _s(s) { }
bool operator () (std::pair<std::string, Container> const& p)
{
return (p.first == _s);
}
std::string _s;
};
#include <iostream>
int main()
{
typedef std::vector<std::pair<std::string, Container> > my_vector;
my_vector v;
v.Push_back(std::make_pair("Hello", Container(42)));
v.Push_back(std::make_pair("World", Container(1729)));
my_vector::iterator i = std::find_if(v.begin(), v.end(), comp("World"));
if (i != v.end())
{
Container& c = i->second;
std::cout << c._c; // <== Prints 1729
}
}
そしてここに 実例 があります。
Boost.Range および Boost.Bind を使用すると、次のことができます。
struct predicate
{
template<class Key, class Pair>
bool operator()(const Key& k, const Pair& p) const
{
return p.first == k;
}
};
// Your vector of pairs
std::vector<std::pair<std:string, Container> v = ...;
// The key you would like to search for
std::string key = ...;
Container& c = boost::find_if(v, boost::bind(predicate(), key, _1))->second;
簡単な解決策があります:use std::copy
およびstd::inserter
:
#include <algorithm>
#include <map>
#include <string>
#include <utility> // pair
#include <vector>
void function()
{
typedef int Data;
typedef std::pair< std::string, Data > String_Data_Pair;
typedef std::vector< String_Data_Pair > String_Data_Pair_Sequence;
typedef std::map< std::string, Data > String_To_Data_Map;
String_Data_Pair_Sequence string_data_pairs;
/* fill 'string_data_pairs' here */
String_To_Data_Map string_to_data_map;
std::copy( string_data_pairs.begin(),
string_data_pairs.end(),
std::inserter( string_to_data_map,
string_to_data_map.begin() /* superfluous, but required */ ) );
}
class SomeClass{
int num;
public:
SomeClass();
void setNumber(int n) const { num = n;}
};
vector<pair<SomeClass,string> > vectr;
for(unsigned int i = 0; i < vectr.size(); i++)
if(vectr[i].second == "key")
vectr[i].first.setNumber(50);
私のために働いた!