有没有人能解释一下最后一行?我需要最终确定两个顶点是否相连。
include <boost/fusion/adapted/std_pair.hpp>
include <boost/spirit/include/qi.hpp>
include <boost/graph/edge_list.hpp>
include <fstream>
typedef std::pair<int,int> Edge;
typedef std::vector<Edge> EdgeList;
typedef boost::edge_list<EdgeList::iterator> Graph;
namespace qi = boost::spirit::qi;
int main()
{
std::ifstream ifs("Graph.txt");
ifs >> std::noskipws;
//std::cout << ifs;
boost::spirit::istream_iterator f(ifs), l;
std::vector<Edge> edges;
bool parse_ok = qi::phrase_parse(f, l, (qi::int_ >> qi::int_) % qi::eol, qi::blank, edges);请解释一下这最后一行:
bool parse_ok = qi::phrase_parse(f, l, (qi::int_ >> qi::int_) % qi::eol, qi::blank, edges);发布于 2017-10-18 15:46:02
看看the documentation,看起来就像“这个库提供了两个免费的函数来快速解析。这些解析器函数有两种形式。第一种形式的解析器在字符级上工作。第二个phrase_parse在短语级上工作,需要跳过解析器。两个版本都可以通过引用来获取属性,这些属性将在成功的解析时保存被解析值。”phrase_parse()定义为
template <typename Iterator, typename Expr, typename Skipper>
inline bool
phrase_parse(
Iterator& first
, Iterator last
, Expr const& expr
, Skipper const& skipper
, BOOST_SCOPED_ENUM(skip_flag) post_skip = skip_flag::postskip);也许这是一个很好的起点。
https://stackoverflow.com/questions/46802313
复制相似问题