Error " no match for call to `(std::string) (unsigned int&)' "

Iniciado por NikNitro!, 31 Enero 2013, 14:39 PM

0 Miembros y 1 Visitante están viendo este tema.

NikNitro!

Buenass a todos.
Resulta que en clase de programación básica de C++, el tema de strings y arrays multidimensionales se me ha atascado. La profesora dice que nos busquemos la vida para resolver sus ejercicios (tranquilos, no os voy a pedir que me hagáis nada. Quiero aprender :) )

Aún no hemos usado clases. Solo procedimientos y funciones, y mi error está en una función que me devuelva un booleano diciendo si dos palabras (en mayúsculas) son o no son anagramas. (Son anagramas si cambiando las letras de orden de una de ellas podemos obtener la otra "caso y saco")



Lo que pretendo es crear dos arrays de 27 int que representen las 27 letras, y que con un bucle for vaya sumando 1 a cada posición cada vez que aparezca la letra. De esta manera acabo comparando los dos arrays y si son iguales, serán anagramas. Espero haberme explicado.

El error lo pueden ver. Me trae loco aunque seguro será una tontería xD

S@lu2 ;)

PD: si tengo más dudas de la misma relación de ejercicios y que no encuentro en la net los pongo en este mismo post?? Creo que podría servir de ayuda a otros como yo ;)

amchacon

Código (cpp) [Seleccionar]
array1[pall[i]-65];

Esta sentencia no hace nada. Si lo que quieres es asignarle al array el valor de pall:

Código (cpp) [Seleccionar]
array1[i] = pall[i] -65;

Lo mismo con el otro array.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

0xDani

El problema esta en estas dos lineas:
Código (cpp) [Seleccionar]
array1[pal1(i)-65];
array2[pal2(j)-65];


Para acceder al caracter que haya en un indice de un string debes usar el operador [], no (). Al usar los parentesis estas haciendo una llamada al constructor de la clase, de ahi el error.

Saludos.
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!

I code for $$$
Hago trabajos en C/C++
Contactar por PM

NikNitro!

Advertencia - mientras estabas escribiendo, una nueva respuesta fue publicada. Probablemente desees revisar tu mensaje.

Aiss, toqueteando se me olvido poner el ++ al final antes de hacerle la foto para que sumara 1 -.-'

Pero vamos, que me has dado la respuesta ^^ estaba utilizando paréntesis en vez de corchetes para definir la posición de los caracteres de la string xP

Aquí está el trozo de código sin fallos:

if(pal1.size() == pal2.size()) {

for (unsigned i = 0; i<pal1.size(); i++){
unsigned a = pal1[i]-65;
array1[a]++;
}
for (unsigned j = 0; j<pal1.size(); j++){
unsigned b = pal2[j]-65;
array2[b]++;
}
}


De camino lo he puesto con una variable para que se vea más claro :)

S@lu2 y gracias ;)

Cita de: NikNitro! en 31 Enero 2013, 14:39 PM
PD: si tengo más dudas de la misma relación de ejercicios y que no encuentro en la net los pongo en este mismo post?? Creo que podría servir de ayuda a otros como yo ;)

Qué me decís de eso?

EDITADO: @0xDani Así es. Gracias a ti también :)

Foxy Rider

#4
¿No es más fácil pasar ambas cadenas a minúsculas, hacerles un sort y comparar resultados?
Si tiene las mismas letras, por ordenamiento numérico terminarían en el mismo lugar y las cadenas deberían ser "equivalentes".

Grosero ejemplo:
Código (cpp) [Seleccionar]
bool isAnagram(string firstWord, string secondWord){

    // To lowercase
    transform (firstWord.begin(), firstWord.end(), firstWord.begin(), ::tolower);
    transform (secondWord.begin(), secondWord.end(), secondWord.begin(), ::tolower);

    // Sort
    sort(firstWord.begin(),firstWord.end(), greater<char>() );
    sort(secondWord.begin(),secondWord.end(), greater<char>() );

    return (firstWord == secondWord);

}


Te olvidas completamente de los for anidados.

Saludos.


NikNitro!

La verdad es que si, pero como ya dije son ejercicios de clase, y aún no hemos dado métodos -.-, y de strings ha dicho que son cadenas de caracteres, que se pueden concatenar, comparar, acceder a terminos dentro de ellas y pasarlas por referencia en vez de por parametros... Tiene a la clase muy liada, la verdad :s

rir3760

Cita de: NikNitro! en 31 Enero 2013, 18:51 PM
La verdad es que si, pero como ya dije son ejercicios de clase, y aún no hemos dado métodos
El problema: ya los están utilizando al llamar a la función miembro "size" de los objetos "pal1" y "pal2".

La mejor solución ya la dio Alex Mtx, si debido a los requisitos en clase solo deben utilizar arrays de caracteres deben tener cuidado con esto:
Código (cpp) [Seleccionar]
anag = (array1==array2);
Ello porque en el caso de los arrays (de cualquier tipo) cuando se utiliza el operador "==" no se comparan sus contenidos, se comparan sus direcciones en memoria, en tu caso esa comparación siempre resultara en el valor false.

Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language