我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;
}
Run Code Online (Sandbox Code Playgroud)
Chr*_*Wue 15
因为你在这里做什么:
for (size_t i = 0; i < N; i++)
suffixes[i] = s.substr(i);
Run Code Online (Sandbox Code Playgroud)
是:创建N长度为0,1,2,...,N的子字符串这些将消耗的内存总量为:1 + 2 + 3 + ... + Nbytes.有了好老高斯,你会发现第一个N数字的总和是:N * (N + 1) / 2
现在,如果设置N = 100,000,则会导致大约5GB的内存消耗 - 大于最大值.除非您在64位系统上运行,否则您的程序通常具有2GB的地址空间.
编辑:我不知道你试图解决的问题是什么,但你的实现看起来很奇怪:
你永远不会使用计算后缀:SuffixArray你使用的唯一功能是lcp不引用存储的suffixes矢量.那么你首先需要它们呢?
| 归档时间: |
|
| 查看次数: |
30497 次 |
| 最近记录: |