0

为了解决我遇到的这个问题,我写了这段小代码:

for (std::list<std::vector<int>>::iterator i = l.begin(); i != l.end(); ++i) {
  for (std::list<std::vector<int>>::iterator j = next(i, 1); j != l.end(); ++j) {
    if (includes((*j).begin(), (*j).end(), (*i).begin(), (*i).end())) {
      l.erase(j++);
    }
  }
}

基本思想是,给定列表的一个元素,从列表的其余部分中删除符合某些标准(在本例中为包含关系)的元素。

执行此操作会触发分段错误,我无法理解。谁能给我一个线索?

4

1 回答 1

0

评论是对的,谢谢。更正后的代码是:

for (std::list<colset>::iterator i = l.begin(); i != l.end(); ++i) {
  std::list<colset>::iterator j = next(i, 1);
  while (j != l.end()) {
    if (includes((*j).begin(), (*j).end(), (*i).begin(), (*i).end())) {
      j = l.erase(j);
    }
    else {
      ++j;
    }
  }
}
于 2013-09-24T17:20:45.687 回答