尝试从BGL开始,这意味着我开始使用很多typedef:
#include <iostream> //std::cin, std::cout
#include <tuple> //std::tie
#include <boost/graph/graph_traits.hpp>
#include <boost/graph/adjacency_list.hpp>
using namespace boost;
typedef adjacency_list<vecS,vecS,undirectedS,no_property,property<edge_weight_t,int> > Graph;
typedef graph_traits<Graph> Traits;
typedef Traits::vertex_descriptor Vertex;
typedef Traits::edge_descriptor Edge;
typedef property_map<Graph, edge_weight_t>::type EdgeWeightMap; //::type necessary (why?)
int main(int argc, char* argv[]){
int n = ...;
Graph g(n);
EdgeWeightMap weight_of;
Edge e;
bool success;
int s,t,w;
std::cin >> s >> t >> w;
tie(e,success) = add_edge(s,t,g);
if(success)weight_of[e] = w;
}
我想知道为什么::type
的typedef中的EdgeWeightMap
是必要的。如果我省略它,我会
错误:'operator []'不匹配(操作数类型为
‘EdgeWeightMap {aka boost::property_map<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::edge_weight_t>}’
和
‘Edge {aka boost::detail::edge_desc_impl<boost::undirected_tag, unsigned int>}’
) weight_of [e] = w;
(抱歉格式,typedef'<
和>
似乎干扰了blockquote)
事实上,当我尝试
时EdgeWeightMap weight_of = get(edge_weight,g);
我得到了
错误:从
转换
‘boost::detail::adj_list_any_edge_pmap::bind_<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::property<boost::edge_weight_t, int>, boost::edge_weight_t>::type {aka boost::adj_list_edge_property_map<boost::undirected_tag, int, int&, unsigned int, boost::property<boost::edge_weight_t, int>, boost::edge_weight_t>}’
到非标量类型
‘EdgeWeightMap {aka boost::property_map<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::edge_weight_t>}’
请求 EdgeWeightMap weight_of = get(edge_weight,g);
现在,我可以看到这些是不同的类型,我没有得到的是为什么它们不同。因为我更愿意避免意外,有人可以告诉我何时需要::type
以及什么时候不能使用?
答案 0 :(得分:1)
通过阅读property_map文档,“property_map”模板旨在提供类型,而不是类型。 property_map结构恰好包含两种类型。 type
和const_type
,分别用于可变和不可变类型。