void pre_process(string& pattern, vector<int>& c)
{
c.reserve(pattern.length());
c[0] = -1;
c[1] = 0;
for(int i=2; i<pattern.length(); ++i)
{
if(pattern[c[i-1]] == pattern[i-1])
c[i] = c[i-1]+1;
else
c[i] = 0;
}
cout << c.size() << endl; //why the size is zero here?
}
在保留向量中的空間之後,我將向值的不同位置賦值。所以不應該增加大小?爲什麼我看到矢量的大小爲零?
將矢量用作固定長度容器的正確方法是什麼?
「我分配值向量的不同位置」的的push_back - 不,你不是;你正在調用UB。 'reserve'不會'調整()'。 –
簡短摘要:由於矢量*的大小*爲零,因此您將矢量的大小視爲零。 –