Cómo encontrar la subcadena en la cadena en C++
-
Usa el método
find
para encontrar una subcadena en una cadena en C++ -
Usa el método
rfind
para encontrar la subcadena en una cadena en C++
Este artículo demuestra métodos para encontrar una subcadena dada en una cadena en C++.
Usa el método find
para encontrar una subcadena en una cadena en C++
La forma más directa de resolver el problema es la función find
, que es un método de string
incorporado, y toma otro objeto de string
como argumento.
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl using std::string;
int main() {
string str1 = "this is random string oiwao2j3";
string str2 = "oiwao2j3";
string str3 = "random s tring";
str1.find(str2) != string::npos
? cout << "str1 contains str2" << endl
: cout << "str1 does not contain str3" << endl;
str1.find(str3) != string::npos
? cout << "str1 contains str3" << endl
: cout << "str1 does not contain str3" << endl;
return EXIT_SUCCESS;
}
Resultado:
str1 contains str2
str1 does not contain str3
Alternativamente, puedes usar find
para comparar rangos de caracteres específicos en dos cadenas. Para ello, debes pasar la posición inicial y la longitud del rango como argumentos al método find
:
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl using std::string;
using std::stoi;
int main() {
string str1 = "this is random string oiwao2j3";
string str3 = "random s tring";
constexpr int length = 6;
constexpr int pos = 0;
str1.find(str3.c_str(), pos, length) != string::npos
? cout << length << " chars match from pos " << pos << endl
: cout << "no match!" << endl;
return EXIT_SUCCESS;
}
Resultado:
6 chars match from pos 0
Usa el método rfind
para encontrar la subcadena en una cadena en C++
El método rfind
tiene una estructura similar al find
. Podemos utilizar rfind
para encontrar la última subcadena o especificar un cierto rango para hacerla coincidir con la subcadena dada.
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl using std::string;
using std::stoi;
int main() {
string str1 = "this is random string oiwao2j3";
string str2 = "oiwao2j3";
str1.rfind(str2) != string::npos
? cout << "last occurrence of str3 starts at pos " << str1.rfind(str2)
<< endl
: cout << "no match!" << endl;
return EXIT_SUCCESS;
}
Resultado:
last occurrence of str3 starts at pos 22
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 FacebookArtículo relacionado - C++ String
- Encuentre el primer carácter repetido en una cadena en C++
- Encuentre la subcadena común más larga en C++
- Poner en mayúscula la primera letra de una cadena en C++
- Comparación de cadenas y caracteres en C++
- Eliminar el último carácter de una cadena en C++
- Obtener el último carácter de una cadena en C++