Создание нового субвектора C ++? - PullRequest
20 голосов
/ 14 марта 2012

Скажем, у меня есть вектор со значениями [1,2,3,4,5,6,7,8,9,10].Я хочу создать новый вектор, который ссылается, например, на [5,6,7,8].Я полагаю, что это просто вопрос создания вектора с указателями или мне нужно push_back для всех промежуточных значений, которые мне нужны?

Ответы [ 4 ]

41 голосов
/ 14 марта 2012

Один из конструкторов 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 голосов
/ 14 марта 2012

Это довольно легко сделать с 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);
4 голосов
/ 14 марта 2012

Вам не нужно использовать push_back, если вы не хотите, вы можете использовать std::copy:

std::vector<int> subvector;
copy ( v1.begin() + 4, v1.begin() + 8, std::back_inserter(subvector) );
3 голосов
/ 14 марта 2012

Я бы сделал следующее:

#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;
}

~

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...