Verificar se o Elemento existe em C++ Vector
-
C++
std::find()
Algoritmo para verificar se um elemento existe em Vector -
C++ Gama Baseada em
for
Loop para Verificar se o Elemento Existe em Vector -
C++
any_of()
Algoritmo para verificar se um elemento existe em Vector
Este artigo demonstra múltiplos métodos sobre como verificar se um elemento existe num vector C++.
C++ std::find()
Algoritmo para verificar se um elemento existe em Vector
O método find
faz parte da biblioteca de algoritmos STL; pode verificar se o elemento em questão existe numa determinada gama. A função procura um factor que é igual ao terceiro parâmetro passado pelo utilizador. O valor de retorno correspondente é o iterador para o primeiro elemento encontrado, ou no caso de nenhum ser encontrado, o fim do intervalo é devolvido.
Note que utilizamos o operador *
para aceder ao valor da string retornada e fazer uma condição de comparação na declaração if
, como se mostra no exemplo seguinte.
#include <algorithm>
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::find;
using std::string;
using std::vector;
int main() {
string element_to_check1 = "nibble";
string element_to_check2 = "nimble";
vector<string> data_types = {"bit", "nibble", "byte", "char",
"int", "long", "long long", "float",
"double", "long double"};
if (*find(data_types.begin(), data_types.end(), element_to_check1) ==
element_to_check1) {
printf("%s is present in the vector\n", element_to_check1.c_str());
} else {
printf("%s is not present in the vector\n", element_to_check1.c_str());
}
if (*find(data_types.begin(), data_types.end(), element_to_check2) ==
element_to_check2) {
printf("%s is present in the vector\n", element_to_check2.c_str());
} else {
printf("%s is not present in the vector\n", element_to_check2.c_str());
}
return EXIT_SUCCESS;
}
Resultado:
nibble is present in the vector
nimble is not present in the vector
C++ Gama Baseada em for
Loop para Verificar se o Elemento Existe em Vector
Um laço for
baseado na gama pode ser utilizado como outra solução para verificar se um dado elemento está presente no vector. Este método é relativamente simples porque itera através do vector; cada iteração verifica a igualdade com uma determinada string. Se um elemento corresponder, uma string de confirmação é impressa, e o laço deixa de utilizar a declaração break
.
#include <iostream>
#include <vector>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
int main() {
string element_to_check = "nibble";
vector<string> data_types = {"bit", "nibble", "byte", "char",
"int", "long", "long long", "float",
"double", "long double"};
for (const auto &item : data_types) {
if (item == element_to_check) {
printf("%s is present in the vector\n", element_to_check.c_str());
break;
}
}
return EXIT_SUCCESS;
}
Resultado:
nibble is present in the vector
C++ any_of()
Algoritmo para verificar se um elemento existe em Vector
Outro método útil do cabeçalho <algorithm>
, que é semelhante ao método find
, é o algoritmo any_of
. O método any_of
verifica se o predicado unário, que é especificado como terceiro argumento, retorna true
para pelo menos um elemento de um determinado intervalo. Neste exemplo, utilizamos uma expressão lambda para construir um predicado unário para comparar elementos vetor.
#include <algorithm>
#include <iostream>
#include <vector>
using std::any_of;
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
int main() {
string element_to_check = "nibble";
vector<string> data_types = {"bit", "nibble", "byte", "char",
"int", "long", "long long", "float",
"double", "long double"};
if (any_of(data_types.begin(), data_types.end(),
[&](const string& elem) { return elem == element_to_check; })) {
printf("%s is present in the vector\n", element_to_check.c_str());
}
return EXIT_SUCCESS;
}
Resultado:
nibble is present in the vector
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