15
我不知道錯誤來自哪裏。好像我將有效的數據傳遞給[]運算符。二進制'[':找不到操作符,它需要類型'const std :: map <_Kty,_Ty>'的左側操作數'
template <class VertexType>
typename map< Vertex<VertexType>, int >::iterator Graph<VertexType>::findEdge(const VertexType& v, const VertexType& w) const
{
map<Vertex<VertexType>, int>::const_iterator iter = vertices[v].second.adjList.find(w);
return iter;
} // end findEdge
錯誤:
error C2678: binary '[' : no operator found which takes a left-hand operand of type 'const std::map<_Kty,_Ty>' (or there is no acceptable conversion)
1> with
1> [
1> _Kty=unsigned int,
1> _Ty=Vertex<unsigned int>
1> ]
1> c:\program files (x86)\microsoft visual studio 10.0\vc\include\map(164): could be 'Vertex<VertexType> &std::map<_Kty,_Ty>::operator [](unsigned int &&)'
1> with
1> [
1> VertexType=unsigned int,
1> _Kty=unsigned int,
1> _Ty=Vertex<unsigned int>
1> ]
1> c:\program files (x86)\microsoft visual studio 10.0\vc\include\map(209): or 'Vertex<VertexType> &std::map<_Kty,_Ty>::operator [](const unsigned int &)'
1> with
1> [
1> VertexType=unsigned int,
1> _Kty=unsigned int,
1> _Ty=Vertex<unsigned int>
1> ]
1> while trying to match the argument list '(const std::map<_Kty,_Ty>, const unsigned int)'
1> with
1> [
1> _Kty=unsigned int,
1> _Ty=Vertex<unsigned int>
1> ]
1> c:\users\user\desktop\cs m20a\topic g project 2\topic g project 2\graph.h(146) : while compiling class template member function 'std::_Tree_iterator<_Mytree> Graph<VertexType>::findEdge(const VertexType &,const VertexType &) const'
1> with
1> [
1> _Mytree=std::_Tree_val<std::_Tmap_traits<Vertex<unsigned int>,int,std::less<Vertex<unsigned int>>,std::allocator<std::pair<const Vertex<unsigned int>,int>>,false>>,
1> VertexType=unsigned int
1> ]
1> c:\users\user\desktop\cs m20a\topic g project 2\topic g project 2\graph.h(52) : while compiling class template member function 'Graph<VertexType>::Graph(unsigned int)'
1> with
1> [
1> VertexType=unsigned int
1> ]
1> c:\users\user\desktop\cs m20a\topic g project 2\topic g project 2\topicg.cpp(17) : see reference to class template instantiation 'Graph<VertexType>' being compiled
1> with
1> [
1> VertexType=unsigned int
1> ]
而且Graph
類:
template <class VertexType>
class Graph
{
private:
// list of all vertices in the graph. assumes non-duplicate data.
map< VertexType, Vertex<VertexType> > vertices;
const unsigned MAX_VERTICES; // Maximum number of vertices the graph can hold.
unsigned numVertices; /** Current number of vertices in the graph. */
unsigned numEdges; /** Number of edges in the graph. */
typename map< Vertex<VertexType>, int >::iterator findEdge(const VertexType& v, const VertexType& w) const;
public:
Graph(unsigned max);
unsigned getNumVertices() const;
unsigned getMaxNumVertices() const;
unsigned getNumEdges() const;
int getWeight(const VertexType& v, const VertexType& w) const;
Graph<VertexType>& addVertex(const VertexType& newValue);
Graph<VertexType>& addEdge(const VertexType& v, const VertexType& w, int weight);
void removeEdge(const VertexType& v, const VertexType& w);
void BFS(const VertexType& v) const;
void display() const;
}; // end Graph
另一種選擇是'std :: map :: at' – PlasmaHH 2013-05-08 09:56:40
@PlasmaHH是的,['std :: map :: at'](http://en.cppreference.com/w/cpp/container/map/at)具有不同的語義,因爲如果該元素不存在,則會引發異常。 – 2014-05-18 16:38:30
聽起來像是一個明顯的遺漏 – 2017-12-06 21:00:43