我已编写代码将字符串解析为名为input的二维向量。我想将第一个索引的字符串放入一个存储lhs和rhs节点的向量中。每个向量的第一个索引应该是lhs,而每个其他字符都应该是rhs。我得到一个超出范围的向量下标,代码循环3次或更多次。我做错了什么?
struct finalNode
{
string rhs;
string lhs;
bool isTerm;
};
void fillGramRules()
{
for (int i = 0; i < input.size(); i++)
{
finalNode fNode;
//attempts to copy first position 0 of every array to string lhs of fnode, this crashes the program
fNode.lhs = input[i][0].symbol;
newNode.isTerm = input[i][0].isTerminal;
for (int j = 1; j < input[i].size()-1; j++)
{
newNode.rhs.append(input[i][j].symbol);
newNode.isTerm = input[i][j].isTerminal;
}
gramRules.push_back(fNode);
}
}
答案 0 :(得分:1)
如果input [i]为空,那么尝试访问input [i] [0]会导致崩溃,所以你可能想先检查一下。
if(!input[i].empty()) {
fNode.lhs = input[i][0].symbol;
newNode.isTerm = input[i][0].isTerminal;
}