2012-03-14 93 views
16

假設我有一個向量值爲[1,2,3,4,5,6,7,8,9,10]。我想創建一個新的矢量,例如,[5,6,7,8]。我想這只是一個用指針創建向量的問題,還是我必須push_back所需的所有中間值?創建一個新的C++子向量?

+0

給出的答案爲止都是很好的選擇。雖然你可以創建一個指向你的子範圍的向量,但你可能不想這樣做。如果原始矢量增長到必須重新分配其內部存儲的程度,那麼指針將全部失效。特別是在處理這樣的小範圍時,使用副本是可取的。 – 2012-03-14 16:18:30

+0

定義「是指」。如果原始矢量改變會發生什麼? – 2012-03-14 16:43:12

+2

可能的重複[從矢量中提取子矢量的最佳方式?](http://stackoverflow.com/questions/421573/best-way-to-extract-a-subvector-from-a-vector) – TobiMcNamobi 2017-04-12 08:38:57

回答

36

一個std::vector的構造的接受範圍:

std::vector<int> v; 

// Populate v. 
for (int i = 1; i <= 10; i++) v.push_back(i); 

// Construct v1 from subrange in v. 
std::vector<int> v1(v.begin() + 4, v.end() - 2); 
4

您不必使用push_back,如果你不想,你可以使用std::copy

std::vector<int> subvector; 
copy (v1.begin() + 4, v1.begin() + 8, std::back_inserter(subvector)); 
+2

Shouldn'你在複製之前是否將子向量初始化爲正確的大小? – obmarg 2012-03-14 16:07:06

+2

@obmarg,或者你可以使用某種形式的'insert_iterator'。 – 2012-03-14 16:09:02

+0

@obmarg是或使用後退插入迭代器 - 「std :: back_inserter」將爲您製作一個 – Flexo 2012-03-14 16:09:35

3

我將執行以下操作:

#include <vector> 
#include <iostream> 

using namespace std; 

void printvec(vector<int>& v){ 
     for(int i = 0;i < v.size();i++){ 
       cout << v[i] << " "; 
     } 
     cout << endl; 
} 

int main(){ 
     vector<int> v; 

     for(int i = 1;i <= 10;i++) v.push_back(i); 
     printvec(v); 

     vector<int> v2(v.begin()+4, v.end()-2); 
     printvec(v2); 
     return 0; 
} 

4

這是很容易做到std::valarray代替矢量:

#include <valarray> 
#include <iostream> 
#include <iterator> 
#include <algorithm> 

int main() { 
    const std::valarray<int> arr={0,1,2,3,4,5,6,7,8,9,10}; 

    const std::valarray<int>& slice = arr[std::slice(5, // start pos 
                4, // size 
                1 // stride 
               )]; 

} 

,這需要的valarray中的「切片」,更比一般的載體。

對於一個矢量可以用,雖然有兩個迭代器的構造做:

const std::vector<int> arr={0,1,2,3,4,5,6,7,8,9,10}; 
std::vector<int> slice(arr.begin()+5, arr.begin()+9);