我的程序中出现bad_alloc
个异常。
这些是限制因素:
有了这些限制,我无法弄清楚为什么我的程序会获得bad_alloc
。
#include <string>
#include <algorithm>
#include <iostream>
#include <vector>
class SuffixArray {
std::vector<std::string> suffixes;
size_t N;
public:
SuffixArray(std::string& s) {
N = s.length();
suffixes.resize(N);
for (size_t i = 0; i < N; i++)
suffixes[i] = s.substr(i);
std::sort(suffixes.begin() , suffixes.end());
}
~SuffixArray() {
}
size_t lcp(std::string& s, std::string& t) {
size_t N = std::min(s.length(), t.length());
for (size_t i = 0; i < N; i++)
if (s[i] != t[i])
return i;
return N;
}
};
int main ( int argc, char **argv) {
int T;
std::cin >> T;
std::vector<size_t> results;
for ( int i = 0; i < T; i++) {
std::string str;
std::cin >> str;
SuffixArray sa(str);
size_t sol = 0;
for ( std::string::iterator it = str.begin(); it != str.end(); ++it) {
std::string target = std::string(it, str.end());
sol += sa.lcp(str, target);
}
results.push_back(sol);
}
for ( std::vector<size_t>::iterator it = results.begin(); it != results.end(); ++it)
std::cout << *it << std::endl;
results.clear();
return 0;
}
答案 0 :(得分:15)
因为你在这里做了什么:
for (size_t i = 0; i < N; i++)
suffixes[i] = s.substr(i);
是:创建长度为0,1,2,...,N的N
子字符串
这些消耗的内存总量为:1 + 2 + 3 + ... + N
个字节。拥有好的高斯,你会发现第一个N
数字的总和是:N * (N + 1) / 2
现在,如果设置N = 100,000,则会导致大约5GB的内存消耗 - 大于最大值。除非您在64位系统上运行,否则您的程序通常拥有2GB的地址空间。
编辑:我不知道您要解决的问题是什么,但您的实施似乎很奇怪:
您永远不会使用计算后缀:您使用的SuffixArray
的唯一功能是lcp
,它不会引用存储的suffixes
向量。那么你首先需要它们呢?