[英]What is the time-complexity of this program (c++)
代碼:
#include <iostream>
#include <vector>
template<typename T>
std::vector<T> flatten(std::vector<std::vector<T>> const &vec)
{
std::vector<T> flattened;
for (auto const &v: vec) {
flattened.insert(flattened.end(), v.begin(), v.end());
}
return flattened;
}
int main()
{
std::vector<std::vector<int>> vec {
{ 1, 2, 3 }, { 4, 5 }, { 6, 7, 8, 9 }
};
std::vector<int> flattened = flatten(vec);
for (int &i: flattened) {
std::cout << i << ' ';
}
return 0;
}
上面代碼的時間復雜度是O(n)還是O(n^2)? 我知道這只是一個 for() 循環,但是在 for 循環中使用 insert() 會使其變為 O(n^2)?
O(Σ i=0 n m i ),
其中n是外部向量的大小, m i是第i個內部向量的大小。
如果外向量的大小和內向量的大小都是 O(n),則相當於 O(n 2 )。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.