字符串::substr() 在 C++ 中的运行时是什么
What is the runtime of string::substr() in C++?
可能的重复项:
std::string::substr 成员函数的复杂性是多少?
我正在尝试对常见的子字符串问题进行朴素的解决方案。 为此,我首先找到第一个字符串的所有子字符串并将它们添加到哈希集中。 然后,我找到第二个字符串的子字符串,看看它们是否存在于哈希集中,如果长度大于当前最大子字符串,则调整最长的子字符串。 我想知道的是:就str1
的长度而言,substr 的运行时间是多少(假设str1
的长度n
)?
#include<hash_set>
string longestCommonSubstring(string str1, string str2) {
hash_set<string> substrings;
string maxSubstring = "";
int maxLength = 0;
for (int i = 0; i < str1.size(); i++) {
for (int j = i+1; j < str1.size(); j++) {
substrings.insert(str1.substr(i,j-i));
}
}
for (int i = 0; i < str2.size(); i++) {
for (int j = i+1; j < str2.size(); j++) {
if (substrings.find(str2.substr(i,j-i)) != substrings.end()) {
if (j-i > maxLength) {
maxSubstring = str2.substr(i,j-1);
maxLength = j - i;
}
}
}
}
}
substr
没有指定的复杂性,但string
具有恒定时间随机访问,并且substr
创建一个给定长度的新字符串,因此它本质上是复制那么多字符的成本。
请注意,GCC 通过引用计数实现std::string
(非法),因此制作副本的实际成本可能会因您的实现而异。
编辑:对不起,我误解了这个问题(我没有正确阅读问题)。
时间复杂度取决于硬件,但可以合理地假设它与请求的子字符串的长度成正比。
该函数的作用只是创建原始字符串的一部分的副本。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么