(ayuda urgente) problema de tablas

Iniciado por original91, 10 Mayo 2010, 17:16 PM

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

original91

Hola buenas, necesito ayuda para resolver un problema que tengo que hacer con C++.
Haber si alguien me puede ayudar :)


Diseñar un algoritmo que, dada una sequencia de caracteres
terminada en punto, escriba la palabra mas "consonantica ", 'es decir, la
que tenga el porcentaje mas alto de consonantes respecto del total de
letras de la palabra
Ejemplo: LOS GUSANOS DE TIERRA.
El% de consonantes sería respectivamente: 66%, 75%, 50% y 60%.
Respuesta: GUSANOS

nicolasblues86

primero deberias poner dicha cadena en una array obviamente una vez que tenes el array lo recorres. contas la cantidad de palabras que hay y mientras haces eso contas todas aquellas letras que no sean vocales
ojo! en conteo de cosonantes tiene que ser hasta que encuentre un espacio asi diferencias una palabra de otra... bueno mas o menos a grandes rasgos se haria asi
espero que te sirva           
Solamente hay 10 clases de personas en el mundo los que saben leer binario y los que no

@synthesize

Postea el código que lleves hecho, no creo que nadie te vaya a hacer los deberes XD

original91

de momento tengo esto:

#include <iostream>
using namespace std;

typedef int TParaulaActual [MAX];
            TParaulaMax [MAX];

void main ()
{
   TParaulaActual paraulaActual;
    TParaulaMax  paraulaMax;
   int index, numFinal, numConsonants;
   double percentatge, percentatgeMax;

   index=0;
   numFinal=0;
   numConsonants=0;
   percentatge=0.0;
   percentatgeMax=0.0;

   cout<<"Entra la seqüència"<<endl;
   cin>>paraulaActual[index];

   while (paraulaActual[index]!='.')
   {
      
       while (paraulaActual[index]!=' ')
       {
          if (((paraulaAct[index]:='a')||(paraulaAct[index]:='e')||(paraulaAct[index]:='i')||(paraulaAct[index]:='o')||(paraulaAct[index]:='u')||(paraulaAct[index]:='A')||(paraulaAct[index]:='E')||(paraulaAct[index]:='I')||(paraulaAct[index]:='O')||(paraulaAct[index]:='U'))
          {
             numConsonants=numConsonants+1;
          }
          index=index+1;
          cin>>paraulaActual[index];
       }
       numFinal=index-1;
       percentatge=(double)numConsonants*100.0/(double)numFinal;

       if (percentatge>percentatgeMax)
       {
          for (index=0<numFinal)
          {
             paraulaMax[index]=paraulaActual[index];
          }
          percentatgeMax=percentatge;
       }
          index=0;
          numFinal=0;
          numConsonants=0;
          percentatge=0.0;
        cin>>paraulaActual[index];
   }
   cout<<"La paraula mes consonantica es:"

      for(index=0<numFinal
      {
         cout<<paraulaMax[index]<<endl;
      }
      cout<<"amb un";
      cout<<percentatgeMax;
      cout<<"de consonants";
}

.:BlackCoder:.

Weno no lo ley todo pero por encima... te vi un par de errores... a pesar de que el algoritmo esta mal planteado...

El typedef deberia ser con char[] no con int[]  :xD...
hay un par de cin que sobran...

Te recomiendo usar la clase string, ya que estas trabajando con C++... Hazle caso a nicolasblues86, y que guardes la posicion final y de incio de la palabra que estas recorriendo y que despues del ' ' guardes la posicion de la palabra que sigue... luego empiezas a contar las consonantes de dicha palabra y si son mas que las consonantes de la palabra con mas consonantes (de las ya recorridas) guardas la posicion de inicio de dicha palabra y tambien la posicion final... Y pes luego la muestras... Creo es mas o menos lo q hiciste pero no lo plateaste bien... Te lo recuerdo porq lo del porcentaje me parece que sobra...

Saludos
"No te esfuerzes por saber mas, esfuerzate por ser el mejor en lo que sabes... Y asi sabras mas" .:BlackCoder:. jajaja




nicolasblues86

bueno mirando lo a grandes rasgos hay varios errores, por ejemplo todos los for estan mal declarados recorda que la sintaxis del bucle for es : primero la inicializacion de la variable a usar; condicion de corte; y por ultimo como queres que aumente la variable, ejemplo:



for (index=0<numFinal) //vos pusistes esto

for (index=0; index<numFinal; index++) //pero seria así





tambien noto que usas muchos "if" a la  hora de detectar las vocales podrias simplificar todo usando switch.




witch (paraulaActual[index])
          {
          case 'a' : case 'A' :;         
          case 'e' : case 'E' :; //etc....
                                        : index++;             
       
          } 



por el momento nada mas que pueda ver despues lo pruebo y me fijo si te puedo ayudar más

saludos!!!

Solamente hay 10 clases de personas en el mundo los que saben leer binario y los que no

original91

Quedaría así pero hay más errores. Se os ocude alguno más??

#include <iostream>
using namespace std;

#define MAX 30
typedef char TParaulaActual [MAX];
typedef char TParaulaMax [MAX];

void main ()
{
   TParaulaActual paraulaActual;
    TParaulaMax  paraulaMax;
   int index, numFinal, numConsonants,MAX;
   double percentatge, percentatgeMax;

   index=0;
   numFinal=0;
   numConsonants=0;
   percentatge=0.0;
   percentatgeMax=0.0;

   cout<<"Entra la seqüència"<<endl;
   cin>>paraulaActual[index];

   while (paraulaActual[index]!='.')
   {
      
       while (paraulaActual[index]!=' ')
       {
          if ((paraulaActual[index]='a')||(paraulaActual[index]='e')||(paraulaActual[index]='i')||(paraulaActual[index]='o')||(paraulaActual[index]='u'))
          {
             numConsonants=numConsonants+1;
          }
          index=index+1;
          cin>>paraulaActual[index];
       }
       numFinal=index-1;
       percentatge=(double)numConsonants*100.0/(double)numFinal;

       if (percentatge>percentatgeMax)
       {
          for (index=0; index<numFinal; index++)
          {
             paraulaMax[index]=paraulaActual[index];
          }
          percentatgeMax=percentatge;
       }
          index=0;
          numFinal=0;
          numConsonants=0;
          percentatge=0.0;
        cin>>paraulaActual[index];
   }
   cout<<"La paraula mes consonantica es:";

      for(index=0; index<numFinal; index++)
      {
         cout<<paraulaMax[index]<<endl;
      }
      cout<<"amb un percentatge";
      cout<<percentatgeMax;
      cout<<"de consonants";
}




MUCHAS GRACIAS

nicolasblues86

#7
buneo primero que nada dos cosas

primero: cunado haces esto "cin>>paraulaActual[index];" si no me equivoco queres poner lo que el usuario escrive en esa variable pero haciendole de esta manera solo incertas el primer caracter, es decir si ingresas "hola" solo se copiaria "h" en el primer elemento del array.
deberias poner "cin>>paraulaActual" y ahi saldria andando

segundo: Estas callendo en un bucle Infinito ya que en un momento inicialisas index a cero dentro del mismo While por lo tanto jamas va a llegar al elemento cuyo valor es  '.' en consecuencia nunca se cumple la condicion de corte y no termina

el ultimo for no es nesesario podes suplantar por  cout<<paraulaMax<<endl

saludos..




   
Solamente hay 10 clases de personas en el mundo los que saben leer binario y los que no

satu

#8
Te corrijo algunas cosas

Cita de: original91 en 12 Mayo 2010, 17:02 PM
Quedaría así pero hay más errores. Se os ocude alguno más??

Código (cpp) [Seleccionar]

#include <iostream>
using namespace std;

#define MAX 30
typedef char TParaulaActual [MAX];
typedef char TParaulaMax [MAX];

void main ()
{
TParaulaActual paraulaActual;
        TParaulaMax  paraulaMax;
int index, numFinal, numConsonants,MAX; // Aqui MAX sobra
double percentatge, percentatgeMax;

index=0;
numFinal=0;
numConsonants=0;
percentatge=0.0;
percentatgeMax=0.0;

cout<<"Entra la seqüència"<<endl;
cin>>paraulaActual[index]; // Aqui sobra el "[index]"

while (paraulaActual[index]!='.')
{

while (paraulaActual[index]!=' ')
{
if ((paraulaActual[index]=='a')||(paraulaActual[index]=='e')||(paraulaActual[index]=='i')||(paraulaActual[index]=='o')||(paraulaActual[index]=='u')) // Estas son comparaciones, por tanto deben ser == no =
{
numConsonants=numConsonants+1;
}
index=index+1;
cin>>paraulaActual[index]; // Aqui sobra toda la linea
}
numFinal=index-1;
percentatge=(double)numConsonants*100.0/(double)numFinal; // numFinal lo tenias inicializado a 0 y sabes lo que pasa cuando divides entre 0  :P

if (percentatge>percentatgeMax)
{
for (index=0; index<numFinal; index++)
{
paraulaMax[index]=paraulaActual[index];
}
percentatgeMax=percentatge;
}
         index=0; // Si vuelves a poner a index a 0 nunca termina
         numFinal=0;
         numConsonants=0;
         percentatge=0.0;
 cin>>paraulaActual[index];
}
cout<<"La paraula mes consonantica es:";

for(index=0; index<numFinal; index++) // Todo el for lo puedes sustituir por un cout<<paraulaMax;
{
cout<<paraulaMax[index]<<endl;
}
cout<<"amb un percentatge";
cout<<percentatgeMax;
cout<<"de consonants";
}




MUCHAS GRACIAS

No me he fijado muy bien asique no se si quedaran mas errores

PD: usa GeSHi para  postear el code
Breakbeat como forma de vida