深度首先搜索构造函数错误

时间:2015-03-05 23:35:26

标签: c++ list depth-first-search

我正在努力使这个深度第一次搜索工作,但我不断得到这个奇怪的错误:

  

' inputEdges'必须由构造函数初始化,而不是由' {---}'

我不知道如何修复它。

/*
 * Adjancency List
*/
#include <iostream>
 #include <cstdlib>
 #include <bits/stdc++.h>
  using namespace std;

 vector<int> edges[5];
     bool visited[5];



 void dfs(int x)
{
visited[x] = true;
for(int i=0; i < edges[x].size(); i++)
    if(!visited[edges[x][i]])
        dfs(edges[x][i]);


}



/*
* Main function
*/
  int main()
 {


for(int i=0; i < 12; i++)
    visited[i] = false;
vector<pair<int, int> > inputEdges{{0, 1}, {0, 3}, {1, 2}, {1, 3}, {2, 4}, {2, 3}, {4, 5}, {5, 6}, {5, 1}, {3, 9}, {8, 7}, {7, 0}, {9, 1}};
for(int i=0; i < inputEdges.size(); i++)
{
    edges[inputEdges[i].first].push_back(inputEdges[i].second);
    edges[inputEdges[i].second].push_back(inputEdges[i].first);
}

dfs(0);
return 0;
}

1 个答案:

答案 0 :(得分:1)

通过大括号括起来列出向量的内容仅在C ++ 11或更高版本中有效。您需要使用符合C ++ 11的编译器来编译此代码。