elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Introducción a Git (Primera Parte)


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  Manejo de Strings
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: Manejo de Strings  (Leído 4,238 veces)
_whiteBird

Desconectado Desconectado

Mensajes: 14


Ver Perfil
Manejo de Strings
« en: 21 Junio 2020, 04:15 am »

Hola, tengo un problema que necesito convertir un string a si misma cambiando las letras a mayúsculas o no en javascript ej

dada la string "string" que al aplicar una funcion nos retorne un array con todas las posibilidades Ej:
[
String,
sTring,
stRing,
strIng,
...
String
STring
StRing
...
STRING
]

No pido que me lo hagan solo que me orienten ya que llevo toda una tarde y no avance nada


En línea

@XSStringManolo
Hacker/Programador
Colaborador
***
Desconectado Desconectado

Mensajes: 2.399


Turn off the red ligth


Ver Perfil WWW
Re: Manejo de Strings
« Respuesta #1 en: 21 Junio 2020, 11:38 am »

Busca el código de un programa de fuerza bruta o generador de diccionarios. Es más difícil de hacer de lo que parece xD.



En línea

Mi perfil de patrocinadores de GitHub está activo! Puedes patrocinarme para apoyar mi trabajo de código abierto 💖

Tryptophan

Desconectado Desconectado

Mensajes: 52


Ver Perfil
Re: Manejo de Strings
« Respuesta #2 en: 21 Junio 2020, 13:06 pm »

Si queres armarlo, vas a necesitar un arbol. La raiz del arbol va a ser la palabra sin transformaciones y cada derivacion del arbol, es una combinacion posible.
En línea

Serapis
Colaborador
***
Desconectado Desconectado

Mensajes: 3.391


Ver Perfil
Re: Manejo de Strings
« Respuesta #3 en: 21 Junio 2020, 22:26 pm »

No es tan complicado...

En primer lugar puesto que se quiere devolver en un array hay que precalcular el tamaño que él mismo tendrá.

Dado que cada carácter tiene 2 variaciones (mayúscula minúscula), que no hay permutaciones de lugar y el tamaño del string...
cantidad = 2^size(delString)
Siendo la cadena: 'string' size=6; 2^6=64. Luego el array tendrá 64 ítems.

La segunda parte, se resuelve en un bucle recursivo... usando grafos. Básicamente es un árbol binario. Nota que no es preciso usar ni construir ninguna estructura especial, más allá del array. Aunque tirando por un árbol binario, te sería más sencillo.

La palabra tendrá un nodo raíz (pongamos '*'), que accede a la primera letra, es decir 's' y 'S' son sus dos nodos hijo.
A su vez cada una de ellas tiene como nodos hijos a la siguiente letra en las dos versiones (mayúscula y minúscula).
Te pongo la jerarquía, de nodos, el de la izquierda es un nodo ya añadido al árbol, los de la derecha son los hijos que se le añaden como hijos:
Código:
*= s|S    <--- hijo izquierdo y derecho del nodo raíz.
s= t|T    <--- hijo izquierdo y derecho del nodo izquierdo de raíz
S= t|T    <--- hijo izquierdo y derecho del nodo derecho de raíz
t= r|R     // etc...
T= r|R
r= i|I
R= i|I
i= n|N
I= n|N
n= g|G
N= g|G
g=
G=

Nota que los dos últimos nodos no tienen hijos...

Ahora si se recorre todas las posibilidades del árbol obtendrás las 64 combinaciones distintas (desprecia el nodo raíz para formar la combinación a la hora de pasarlo al array de destino).
El problema de usar una estructura de árbol, es que empleará más espacio del strictamente necesario, ya que por ejemplo, al llegar al último nodo, n y N, cada uno de ellos tendrán por nodos finales 'g' y 'G', es decir se habrá añadido 32 nodos 'g' y 32 nodos 'G'.
Estrictamente basta un array de una estructura simple con cada uno de esos nodos:
Código:
Estructura Nodo
    char Nombre
    byte NumHijos
    arrayde Nodo Hijos()   // 2
    boleano Terminal
    entero Indice
Fin estructura

Array de nodo Nodos()

Luego se puede pasar como una cadena de texto, o un array de texto, el contenido de más arriba '*= s|S, s= t|T, S= t|T ..." , el caso es una función recibe y parsea dicho contenido al array Nodos() que se compone de la estructura nodo.
Rellenando dicho array quedaría así:
Código:
nodos(0).Nombre = "*"
nodos(0).NumHijos = 2
nodos(0).Hijos(0) =  nodos(1) // 's'
nodos(0).Hijos(1) =  nodos(2) // 'S'
nodos(0).Indice = 0
nodos(0).Terminal = FALSE

nodos(1).Nombre = "s"
nodos(1).NumHijos = 2
nodos(1).Hijos(0) =  nodos(3)  // 't'
nodos(1).Hijos(1) =  nodos(4)  // 'T'
nodos(1).Indice = 1
nodos(1).Terminal = FALSE

nodos(2).Nombre = "S"
nodos(2).NumHijos = 2
nodos(2).Hijos(0) =  nodos(3)  // 't'
nodos(2).Hijos(1) =  nodos(4)  // 'T'
nodos(2).Indice = 2
nodos(2).Terminal = FALSE
...
...
...

nodos(10).Nombre = "N"
nodos(10).NumHijos = 2
nodos(10).Hijos(0) =  nodos(11)  // 'g'
nodos(10).Hijos(1) =  nodos(12)  // 'G'
nodos(10).Indice = 10
nodos(10).Terminal = FALSE

nodos(11).Nombre = "g"
nodos(11).NumHijos = 0
nodos(11).Hijos // no dimensionado.
nodos(11).Indice = 11
nodos(11).Terminal = TRUE

nodos(12).Nombre = "G"
nodos(12).NumHijos = 0
nodos(12).Hijos // no dimensionado.
nodos(12).Indice = 12
nodos(12).Terminal = TRUE

Ahora con dciho array una función recorre recursivamente, tomando en cada ciclo el 'nombre' del nodo visitado, que se usa para ir concatenando la variación adecuada. La recursión finaliza cuando el nodo es terminal...
Como cada nodo tiene 2 hijos (podrían tener 1 o más), se precisa tambén un bucle interno para dicho recorrido de hijos.

La función de recorrido se invoca desde la que parsea la entrada,  sería más o menos así:

Código:
Funcion Recorrer(nodo n, entero i, entero xWord, string parcial, array string Salida() )
    entero j, k

    bucle para k desde 0 hasta n.NumHijos-1
        j = n.Hijos(k).Indice
        
        parcial.Add( nodos(j).Nombre, i)         //añade el char de 'nodos(j).Nombre' en la posición 'i' del string 'parcial'
        i +=1
        
        Si (nodos(j).Terminal = TRUE)
            Salida(xWord) = parcial
            xWord +=1
        Sino
            Recorrer(nodos(j), i, xWord, parcial, Salida)
        fin si

        i -=1
        // estrictament esto no es necesario, ya que 'i' permitirá sobrescribir sin borrar el previo.
        parcial.Remove( i)     // elimina de parcial el char en la posición 'i'
    Siguiente
Fin funcion
Esta función (así de simple), recorre todas las combinaciones posibles.

La función que parsea el texto de entrada, lo dejo a tu esfuezo, pués se trata de 'desguazar' dicha cadena en sus nodos, y cada nodos en sus elementos, para generar el array de nodos. Se requieren dos bucles, en el primero se crea el array con los 13 nodos (0 a 12, el 0 es el raíz), aplicando nombre, indice (el mismo del contador del bucle), número de hijos y si es o no terminal. Es terminal si no tiene hijos (caso de 'g' y 'G'). En el segundo bucle, se rellenan los datos que no se conocían , esto es, los hijos, requiere una búsqueda. Por ejemplo: Sabiendo que 't' tiene como hijos a 'r' y a 'R', precisa buscar que posicón ocupan esos nodos 'r' y 'R', para terminar de rellenar los datos (es decir busca rel índice de ?????:
Código:
nodos(3).Hijos(0) =  nodos(?????)  // 'r'
nodos(3).Hijos(1) =  nodos(?????)  // 'R'

La funcion principal, invoca a dos, una para generar los nodos y luego para realizar el recorrido.
Código:
Array de String() = funcion CombinatoriaMayusMinus(string Palabra)
    entero sizeArray = (2 ^ palabra.size)
    array de String Salida(0 a sizeArray -1)
    string s = Palabra
    entero indexChar =0, indexWord =0


    Llamada a ParseEntrada(Palabra)
    Llamada a Recorrer(nodos(0), indexChar, indexWord , s, Salida)
    Devolver  Salida
fin funcion


La función que construye el array de la estructura 'nodo'...
Nota que aquí tomamos la palabra entrada, sin generar las producciones comentadas al principio (dada la simplicidad de dichas producciones, es todo muy deducible).
Código:
Funcion ParseEntrada(string Palabra)
    entero k, j, i, n

    dimensionar nodos(0 a palabra.size * 2)    // esta declarado a nivel raiz (ver más arriba)
    
    nodo(0).Nombre = "*"    // <--- nodo raíz
    nodo(0).Indice = 0
    nodo(0).NumHijos = 2
    nodo(0).Terminal = False

    j = 0
    bucle para k desde 0 hasta palabra.Size -2  // la última letra es terminal y no tiene 'siguiente letra'
        j +=1
        nodo(j).Nombre = palabra.charAt(k).ToLower   //// <---- la minuscula
        nodo(j).Indice = j
        nodo(j).NumHijos = 2   ' porque es mayus y minus
        nodo(j).Terminal = False
        
        j +=1
        nodo(j).Nombre = palabra.charAt(k).ToUpper    // <---- la mayuscula
        nodo(j).Indice = j
        nodo(j).NumHijos = 2   ' porque es mayus y minus
        nodo(j).Terminal = False
    Siguiente

    j +=1
    nodo(j).Nombre = palabra.charAt(k).ToLower   //// <---- la minuscula
    nodo(j).Indice = j
    nodo(j).NumHijos = 0  
    nodo(j).Terminal = TRUE
        
    j +=1
    nodo(j).Nombre = palabra.charAt(k).ToUpper    // <---- la mayuscula
    nodo(j).Indice = j
    nodo(j).NumHijos = 0
    nodo(j).Terminal = TRUE

// -------------------- fin primera fase ----------------
  
    // Ahora falta asociar los hijos a cada nodo.
    //    Siendo siempre solo 2 hijos es muy simple y no hace falta esta busqueda, es deducible
    //    pero en casos con diferente número de hijos, tocará buscar...
    n = (j-2)
    bucle para k desde 0 hasta n
        bucle para i desde 0 hasta nodos(k).NumHijos -1
            j = BuscarNodo(... )  // <--- esta función y los parámetros que deba recibir, los dejo a tu esfuerzo
            // pero para la palabra 'string', para '*' buscamos nodo(?).nombre, donde nombre son  's' y 'S' (en cada ciclo)
            //    para 'R' buscamos 'i' e 'I', etc...
            nodos(k).Hijos(i) = nodos(j)
        Siguiente
    Siguiente

// -------------------- fin segunda fase ----------------
fin funcion

Una captura:
(nota que yo he dejado el 'nombre' de la raíz  '*', con cada uno)




La salida completa sería:
Citar
*= s|S; s= t|T; S= t|T; t= r|R; T= r|R; r= i|I; R= i|I; i= n|N; I= n|N; n= g|G; N= g|G; g=; G=
Nodo Inicial: *
Nodos Finales: g, G


1 ---> *string   0
1 ---> *strinG   0
1 ---> *striNg   0
1 ---> *striNG   0
1 ---> *strIng   0
1 ---> *strInG   0
1 ---> *strINg   0
1 ---> *strING   0
1 ---> *stRing   0
1 ---> *stRinG   0
1 ---> *stRiNg   0
1 ---> *stRiNG   0
1 ---> *stRIng   0
1 ---> *stRInG   0
1 ---> *stRINg   0
1 ---> *stRING   0
1 ---> *sTring   0
1 ---> *sTrinG   0
1 ---> *sTriNg   0
1 ---> *sTriNG   0
1 ---> *sTrIng   0
1 ---> *sTrInG   0
1 ---> *sTrINg   0
1 ---> *sTrING   0
1 ---> *sTRing   0
1 ---> *sTRinG   0
1 ---> *sTRiNg   0
1 ---> *sTRiNG   0
1 ---> *sTRIng   0
1 ---> *sTRInG   0
1 ---> *sTRINg   0
1 ---> *sTRING   0
1 ---> *String   0
1 ---> *StrinG   0
1 ---> *StriNg   0
1 ---> *StriNG   0
1 ---> *StrIng   0
1 ---> *StrInG   0
1 ---> *StrINg   0
1 ---> *StrING   0
1 ---> *StRing   0
1 ---> *StRinG   0
1 ---> *StRiNg   0
1 ---> *StRiNG   0
1 ---> *StRIng   0
1 ---> *StRInG   0
1 ---> *StRINg   0
1 ---> *StRING   0
1 ---> *STring   0
1 ---> *STrinG   0
1 ---> *STriNg   0
1 ---> *STriNG   0
1 ---> *STrIng   0
1 ---> *STrInG   0
1 ---> *STrINg   0
1 ---> *STrING   0
1 ---> *STRing   0
1 ---> *STRinG   0
1 ---> *STRiNg   0
1 ---> *STRiNG   0
1 ---> *STRIng   0
1 ---> *STRInG   0
1 ---> *STRINg   0
1 ---> *STRING   0

Número de nodos: 13
Total de caminos: 126
Total de Salidas: 64

La opción de resolverlo con un árbol, es también adecuada, como te describí más arriba... pero elige el modelo que mejor veas factible de entender e implementar...
« Última modificación: 21 Junio 2020, 22:40 pm por NEBIRE » En línea

@XSStringManolo
Hacker/Programador
Colaborador
***
Desconectado Desconectado

Mensajes: 2.399


Turn off the red ligth


Ver Perfil WWW
Re: Manejo de Strings
« Respuesta #4 en: 21 Junio 2020, 23:06 pm »

Tengo que aprenderme esto xD

Guardado
En línea

Mi perfil de patrocinadores de GitHub está activo! Puedes patrocinarme para apoyar mi trabajo de código abierto 💖

Emertech

Desconectado Desconectado

Mensajes: 21


:)


Ver Perfil
Re: Manejo de Strings
« Respuesta #5 en: 26 Junio 2020, 01:57 am »

Hola, tengo un problema que necesito convertir un string a si misma cambiando las letras a mayúsculas o no en javascript ej

dada la string "string" que al aplicar una funcion nos retorne un array con todas las posibilidades Ej:
[
String,
sTring,
stRing,
strIng,
...
String
STring
StRing
...
STRING
]

Hay 1 modo más sencillo basado en un método que hice hace tiempo.
-   Crear una matriz m * n, donde m = nro de combinaciones y n = nro de letras.
-   Separar la palabra en 2 filas (sea matriz bidimensional o 2 unidimensionales) separando cada letra en una columna de cada fila, la 1era con sus letras en mayúscula y la 2da con sus letras en minúscula.
-   Llenar la matriz m*n con la fila de letras minúsculas.
-   Reemplazar de derecha a izquierda las columnas de la matriz m*n con la fila de las letras mayúsculas intercalando cada columna empezando con el valor de 1 e incrementando este valor para las siguientes columnas con el doble del valor anterior (dejo unas imágenes en Excel para ilustrar).



-   Dejo un código de prueba en c++ para demostrar lo que menciono que se puede hacer en javascript similar.



Código
  1. #include <iostream>
  2.  
  3. int main()
  4. {
  5. char mat01[6][6] = { {'S','T','R','I','N','G'}, {'s','t','r','i','n','g'} };
  6. char mat02[64][6];
  7.  
  8. int filMax = 64;
  9. int colMax = 6;
  10.  
  11. for (int fil = 0; fil < filMax; fil++)
  12. {
  13. for (int col = 0; col < colMax; col++)
  14. {
  15. mat02[fil][col] = mat01[1][col];
  16. }
  17. }
  18. int iRep = 1;
  19. for (int col = colMax - 1; col >= 0; col--)
  20. {
  21. int iFlag = 0;
  22. int iCont = 0;
  23. for (int fil = 0; fil < filMax; fil++)
  24. {
  25. if (iCont == 0)iFlag = 0;
  26. if (iCont == iRep)iFlag = 1;
  27.  
  28. if (iFlag == 1)mat02[fil][col] = mat01[0][col];
  29.  
  30. if (iCont < iRep && iFlag == 0)
  31. {
  32. iCont++;
  33. }
  34.  
  35. if (iCont > 0 && iFlag == 1)
  36. {
  37. iCont--;
  38. }
  39. }
  40. iRep = iRep * 2;
  41. }
  42. for (int fil = 0; fil < filMax; fil++)
  43. {
  44. std::cout << "Combinacion: " << fil + 1 << " ";
  45. for (int col = 0; col < colMax; col++)
  46. {
  47. std::cout << mat02[fil][col];
  48. }
  49. std::cout << std::endl;
  50. }
  51. }
« Última modificación: 26 Junio 2020, 02:01 am por Emertech » En línea

Tachikomaia


Desconectado Desconectado

Mensajes: 1.390


Hackentifiko!


Ver Perfil
Re: Manejo de Strings
« Respuesta #6 en: 26 Junio 2020, 02:37 am »

A mí lo que se me ocurre es ir incrementando un "número binario" así:
000000
000001
000010
etc, de modo que un 0 representa una minúscula y 1 una mayúscula.

Pero el código tendría que pensar cómo sería y no tengo ganas ni tanta capacidad de hacerlo.
En línea

Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
manejo de strings
Programación Visual Basic
elrecar 6 2,709 Último mensaje 16 Octubre 2007, 20:28 pm
por elrecar
Duda sobre manejo de strings en bash
Scripting
rastanthology 7 5,428 Último mensaje 28 Septiembre 2010, 00:00 am
por rastanthology
Funciones PROPIAS para manejo de strings en C/C++ « 1 2 »
Programación C/C++
Álvaro G. Tenorio 12 7,906 Último mensaje 3 Septiembre 2013, 09:44 am
por eferion
MANEJO DE STRINGS EN VB.NET
.NET (C#, VB.NET, ASP)
igustin10 2 2,612 Último mensaje 21 Diciembre 2016, 15:49 pm
por igustin10
Manejo de strings enormes y caracteres?
Programación C/C++
@XSStringManolo 6 2,943 Último mensaje 11 Junio 2019, 20:15 pm
por @XSStringManolo
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines