簡體   English   中英

這個程序的時間復雜度是多少(c++)

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM