C++ 演算法庫 - copy_n() 函式



描述

C++ 函式std::algorithm::copy_n() 複製前n個數到一個新的位置。如果nn的值為負數,則函式什麼也不做。

宣告

以下是來自 std::algorithm 標頭檔案的 std::algorithm::copy_n() 函式宣告。

C++11

template <class InputIterator, class Size, class OutputIterator>
OutputIterator copy_n (InputIterator first, Size n, OutputIterator result);

引數

  • first − 輸入迭代器,指向被搜尋序列的起始位置。

  • n − 要複製的元素個數。

  • result − 輸出迭代器,指向新序列中的起始位置。

返回值

返回一個迭代器,指向已複製元素的目標範圍的末尾。

異常

如果元素賦值或迭代器操作丟擲異常,則丟擲異常。

請注意,無效引數會導致未定義的行為。

時間複雜度

firstlast.

之間的距離線性相關。

示例

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main(void) {
   vector<int> v1 = {1, 2, 3, 4, 5};
   vector<int> v2(3);

   copy_n(v1.begin(), 3, v2.begin());

   cout << "Vector v2 contains following elements" << endl;

   for (auto it = v2.begin(); it != v2.end(); ++it)
      cout << *it << endl;

   return 0;
}

讓我們編譯並執行上述程式,這將產生以下結果:

Vector v2 contains following elements
1
2
3
algorithm.htm
廣告