Redimensionar array em C++
-
Utilizar o método de
resize
para redimensionar um array em C++ -
Utilizar o método
erase
para reduzir o número de elementos no Array em C++ - Utilizar função definida à medida para redimensionar um array em C++
Este artigo irá introduzir múltiplos métodos de como redimensionar um array em C++.
Utilizar o método de resize
para redimensionar um array em C++
Uma vez que não é suposto os contentores de comprimento fixo serem redimensionados em C++, vamos concentrar-nos na classe std::vector
. O resize
é a função integrada do contentor vector
, e altera o número de elementos que o vector contém. A função pode reduzir o número de elementos se o primeiro argumento count
for inferior ao tamanho actual do vector
. Caso contrário, se o argumento count
for maior do que o tamanho do vector, resize
insere elementos adicionais com valores por defeito de 0 ou o utilizador pode fornecer o valor desejado como segundo argumento para a função.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
template <typename T>
void printVectorElements(vector<T> &vec) {
for (auto i = 0; i < vec.size(); ++i) {
cout << vec.at(i) << "; ";
}
cout << endl;
}
int main() {
vector<int> i_vec1 = {12, 32, 43, 53, 23, 65, 84};
cout << "i_vec1 : ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
i_vec1.resize(i_vec1.size() - 2);
cout << "i_vec1 (resized -2): ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
cout << endl;
return EXIT_SUCCESS;
}
Resultado:
i_vec1 : 12; 32; 43; 53; 23; 65; 84;
size: 7
i_vec1 (resized -2): 12; 32; 43; 53; 23;
size: 5
Utilizar o método erase
para reduzir o número de elementos no Array em C++
A função erase
é outro método integrado da classe std::vector
que pode remover um único elemento do vector
ou mesmo apagar toda a gama especificada com os iteradores correspondentes.
No exemplo seguinte, um determinado intervalo desde o elemento 2 até ao fim é removido do vector
de inteiros. Note-se que é prática comum passar os parâmetros de intervalo com iteradores de begin
/end
.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
template <typename T>
void printVectorElements(vector<T> &vec) {
for (auto i = 0; i < vec.size(); ++i) {
cout << vec.at(i) << "; ";
}
cout << endl;
}
int main() {
vector<int> i_vec1 = {12, 32, 43, 53, 23, 65, 84};
cout << "i_vec1 : ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
i_vec1.erase(i_vec1.begin() + 2, i_vec1.end());
cout << "i_vec1 (resized): ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
cout << endl;
return EXIT_SUCCESS;
}
Resultado:
i_vec1 : 12; 32; 43; 53; 23; 65; 84;
size: 7
i_vec1 (resized): 12; 32;
size: 2
Utilizar função definida à medida para redimensionar um array em C++
Em alternativa, podemos definir uma função separada que itera através do vector e remove um determinado número de elementos do fim do vector. Isto pode ser implementado utilizando a função integrada pop_back
que remove o último elemento em vector
. Como mostrado na amostra de código seguinte, o modelo da função resizeVector
é definido para tomar um vector do tipo T
e vários elementos a remover do mesmo.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
template <typename T>
void printVectorElements(vector<T> &vec) {
for (auto i = 0; i < vec.size(); ++i) {
cout << vec.at(i) << "; ";
}
cout << endl;
}
template <typename T>
void resizeVector(vector<T> &vec, int elems) {
for (auto i = 0; i < elems; ++i) {
vec.pop_back();
}
}
int main() {
vector<int> i_vec1 = {12, 32, 43, 53, 23, 65, 84};
cout << "i_vec1 : ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
resizeVector(i_vec1, 3);
cout << "i_vec1 (resized): ";
printVectorElements(i_vec1);
cout << "size: " << i_vec1.size() << endl;
cout << endl;
return EXIT_SUCCESS;
}
Resultado:
i_vec1 : 12; 32; 43; 53; 23; 65; 84;
size: 7
i_vec1 (resized): 12; 32; 43; 53;
size: 4
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn Facebook