本文整理汇总了C++中States::end方法的典型用法代码示例。如果您正苦于以下问题:C++ States::end方法的具体用法?C++ States::end怎么用?C++ States::end使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类States
的用法示例。
在下文中一共展示了States::end方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: fill
// 所有能从from通过EPSILON能达到的NFA状态(包括from)
static States fill(const std::vector<NFATran>& trans, const States& last, const States& from, bool* is_last) {
std::queue<int> q;
for (States::const_iterator it = from.begin();
it != from.end(); ++it) {
q.push(*it);
}
// ends表示终点(即最终状态),要判断这次转移是否只有-1
States ends;
States to;
while (!q.empty()) {
int s = q.front();
q.pop();
to.insert(s);
if (last.find(s) != last.end()) {
*is_last = true;
}
if (s == -1) {
ends.insert(-1);
continue;
}
const NFATran& tran = trans[s];
NFATran::const_iterator it = tran.find(EPSILON);
if (it == tran.end()) {
ends.insert(s);
continue;
}
const States& next = it->second;
for (States::const_iterator nit = next.begin();
nit != next.end(); ++nit) {
if (to.find(*nit) == to.end()) {
q.push(*nit);
}
}
}
if (ends.find(-1) == ends.end() || ends.size() > 1) {
to.erase(-1);
} else {
to.clear();
to.insert(-1);
}
return to;
}
示例2: expand
// 所有从from通过一次ch到达的NFA状态
// 这里有-1,表示上次fill只有一个最终状态,即-1
static States expand(const std::vector<NFATran>& trans, const States& from, char ch) {
States to;
for (States::const_iterator it = from.begin();
it != from.end(); ++it) {
int s = *it;
if (s == -1) {
to.clear();
to.insert(-1);
break;
}
const NFATran& tran = trans[s];
NFATran::const_iterator tit = tran.find(ch);
if (tit == tran.end()) {
continue;
}
const States& next = tit->second;
for (States::const_iterator nit = next.begin();
nit != next.end(); ++nit) {
to.insert(*nit);
}
}
return to;
}
示例3: advance_current_states
void Tracematch::advance_current_states(States& current_states, UINT32 symbol_id)
{
list<Vertex> next_states;
unordered_set<Vertex> visited_states;
OutEdgeIterator oei, oei_end;
list<Vertex>::iterator i = current_states.begin();
while (i != current_states.end()) {
if (visited_states.find(*i) == visited_states.end()) {
/* Unvisited state */
for (boost::tie(oei, oei_end) = boost::out_edges(*i, graph);
oei != oei_end; ++oei) {
/* Epsilon transition */
if (graph[*oei].symbol_id == SYMBOL_ID_EPSILON) {
current_states.push_back(boost::target(*oei, graph));
}
/* Match */
else if (graph[*oei].symbol_id == symbol_id) {
next_states.push_back(boost::target(*oei, graph));
}
}
visited_states.insert(*i);
}
/* Erase this element */
current_states.erase(i++);
}
current_states = next_states;
}
示例4: current_states_is_end
bool Tracematch::current_states_is_end(const States& current_states)
{
States states = current_states;
unordered_set<Vertex> visited_states;
OutEdgeIterator oei, oei_end;
list<Vertex>::iterator i = states.begin();
while (i != states.end()) {
if (visited_states.find(*i) == visited_states.end()) {
/* Unvisited state */
if (*i == graph_properties.end) {
return true;
}
for (boost::tie(oei, oei_end) = boost::out_edges(*i, graph); oei != oei_end; ++oei) {
/* Epsilon transition */
if (graph[*oei].symbol_id == SYMBOL_ID_EPSILON) {
states.push_back(boost::target(*oei, graph));
}
}
visited_states.insert(*i);
}
/* Erase this element */
states.erase(i++);
}
return false;
}
示例5: merge_tags
static void merge_tags(const States& states,
const std::map<size_t, Tag>& from,
int s, std::map<size_t, Tag> *to) {
size_t size = states.size();
for (States::const_iterator it = states.begin();
it != states.end(); ++it) {
assert(*it >= 0);
std::map<size_t, Tag>::const_iterator fit = from.find(*it);
if (fit != from.end()) {
Tag& tag = (*to)[s];
tag.insert(fit->second.begin(), fit->second.end());
}
}
}
示例6: build
bool DFAConverter::build(int start, const States& last,
const std::vector<NFATran>& trans,
const std::map<size_t, Tag>& tags) {
reset();
std::map<States, int> nfa_to_dfa;
States v;
v.insert(-1);
nfa_to_dfa[v] = -1;
v.clear();
bool is_last = false;
v.insert(start);
v = fill(trans, last, v, &is_last);
_start = new_state();
nfa_to_dfa[v] = _start;
if (is_last) {
_last.insert(_start);
}
merge_tags(v, tags, _start, &_tags);
std::queue<States> q;
q.push(v);
while (!q.empty()) {
v = q.front();
q.pop();
int from = nfa_to_dfa[v];
std::set<Byte> dedup;
dedup.insert(EPSILON);
for (States::const_iterator it = v.begin();
it != v.end(); ++it) {
int s = *it;
assert(s >= 0);
const NFATran& tran = trans[s];
for (NFATran::const_iterator it = tran.begin();
it != tran.end(); ++it) {
if (dedup.find(it->first) != dedup.end()) {
continue;
}
is_last = false;
States next = expand(trans, v, it->first);
next = fill(trans, last, next, &is_last);
int to = -1;
if (nfa_to_dfa.find(next) == nfa_to_dfa.end()) {
to = new_state();
nfa_to_dfa[next] = to;
q.push(next);
if (is_last) {
_last.insert(to);
}
merge_tags(next, tags, to, &_tags);
} else {
to = nfa_to_dfa[next];
}
_trans[from][it->first] = to;
dedup.insert(it->first);
}
}
}
return true;
}