Programa C++ para verificar si las strings son rotaciones entre sí o no | conjunto 2

Dadas dos strings s1 y s2, compruebe si s2 es una rotación de s1. 
Ejemplos: 

Input : ABACD, CDABA
Output : True

Input : GEEKS, EKSGE
Output : True

Hemos discutido un enfoque en una publicación anterior que maneja la coincidencia de substrings como un patrón. En esta publicación, utilizaremos la construcción lps (prefijo propio más largo que también es sufijo) del algoritmo KMP , que ayudará a encontrar la coincidencia más larga del prefijo de la string b y el sufijo de la string a. Por lo cual conoceremos el punto de giro , a partir de este punto emparejar los personajes. Si todos los caracteres coinciden, entonces es una rotación, de lo contrario no.
A continuación se muestra la implementación básica del enfoque anterior. 
 

C++

// C++ program to check if 
// two strings are rotations
// of each other
#include<bits/stdc++.h>
using namespace std;
bool isRotation(string a, 
                string b)
{
  int n = a.length();
  int m = b.length();
  if (n != m)
    return false;
  
  // create lps[] that 
  // will hold the longest
  // prefix suffix values 
  // for pattern
  int lps[n];
  
  // length of the previous 
  // longest prefix suffix
  int len = 0;
  int i = 1;
    
  // lps[0] is always 0
  lps[0] = 0; 
  
  // the loop calculates 
  // lps[i] for i = 1 to n-1
  while (i < n) 
  {
    if (a[i] == b[len]) 
    {
      lps[i] = ++len;
      ++i;
    }
    else 
    {
      if (len == 0) 
      {
        lps[i] = 0;
        ++i;
      }
      else 
      {
        len = lps[len - 1];
      }
    }
  }
  
  i = 0;
  
  // Match from that rotating
  // point
  for (int k = lps[n - 1]; 
           k < m; ++k) 
  {
    if (b[k] != a[i++])
      return false;
  }
  return true;
}
  
// Driver code
int main()
{
  string s1 = "ABACD";
  string s2 = "CDABA";
  cout << (isRotation(s1, s2) ? 
           "1" : "0");
}
  
// This code is contributed by Chitranayal

Producción: 
 

1

Complejidad temporal: O(n) 
Espacio auxiliar: O(n)

Consulte el artículo completo sobre Comprobar si las strings son rotaciones entre sí o no | Set 2 para más detalles!

Publicación traducida automáticamente

Artículo escrito por GeeksforGeeks-1 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *