Cómo encontrar la subcadena en la cadena en C++
- 
          
            Usa el método findpara encontrar una subcadena en una cadena en C++
- 
          
            Usa el método rfindpara 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++
