Prioridad y asociatividad de los operadores en C. (Programa propio)

Iniciado por NOB2014, 6 Abril 2014, 21:16 PM

0 Miembros y 2 Visitantes están viendo este tema.

NOB2014

Hola a todos y que tengan un muy buen día.-
Por el enunciado se darán cuenta de lo que deseo hacer, si me dejan ser prejuicio muchos dirán que ganas de complicarse por algo que el compilador de C lo efectúa perfectamente, si bien esto es cierto tengo mucha fe que este hilo me proporcionara mucho conocimiento (intuición, corazonada).-
Lo primero que deseo hacer es poner en una variable int (9 - 2) y borrarlo de la variable cadena, si bien logro extraer la cadena con un inicio correcto pero no logro el corte en el último paréntesis.-
Por último ¿lo harian de otra manera?.-     

#include <stdio.h>
#include <string.h>

int main(){
char cadena[100] = "3 * 5 + (9 - 2) + 5", *enc = NULL;

enc = strchr(cadena, '(');

printf("\n %s", enc);

printf("\n\n");
return 0;
}


Saludos y desde ya muchas gracias.
Daniel
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor y cuando lo abrazas dejan de causar dolor.-

leosansan


Lo que me gusta del C es su minimalismo: por qué usar funciones que tu te puedes crear, pasando de las librerías correspondientes  ;):

Citar

9 - 2


Código (cpp) [Seleccionar]
#include <stdio.h>

int main(){
  int i,j,i0,i1;
  char cadena[100] = "3 * 5 + (9 - 2) + 5", cadena1[100];
  for (i=0;cadena[i]; i++){
    if (cadena[i]=='(')
      i0=i;
    if (cadena[i]==')'){
      i1=i;
      break;
    }
  }
  for (i=i0+1,j=0;i<i1; i++,j++)
    cadena1[j]=cadena[i];
  cadena1[j]='\0';
  printf("\n %s", cadena1);
  printf("\n\n");
  return 0;
}


¡¡¡¡ Saluditos! ..... !!!!



NOB2014

Hola a todos.
Bueno pude lograr un avance pero no consigo insertar el resultado de auxiliar en cadena, créanme que estuve practicando pero me atrevo a pedirle ayuda un tanto apresurado por que estoy ansioso por avanzar.-

#include <stdio.h>
#include <stdlib.h>

int main(){
int i, j, inicio, final;
char cadena[100] = "3 * 5 + (9 - 2) + 5", auxiliar[100];

for (i=0;cadena[i]; i++){
if (cadena[i]=='(')
inicio=i;
if (cadena[i]==')'){
final=i;
break;
}
}

for (i=inicio+1,j=0;i<final; i++,j++){
auxiliar[j]=cadena[i];
}

j = final - inicio;
for(i=inicio; i < inicio+j+1 ; i++){
cadena[i] = ' ';
}

auxiliar[j]='\0';

printf("\n auxiliar = %s  cadena = %s", auxiliar, cadena);

printf("\n\n");
return 0;
}


Saludos.
Daniel
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor y cuando lo abrazas dejan de causar dolor.-

rir3760

El primer cambio que debes hacer es almacenar el '\0' en el array "auxiliar" justo después del segundo bucle y para sustituir la cadena entre paréntesis por espacios el tercer bucle es demasiado complicado.

Con los cambios:
#include <stdio.h>

int main(void)
{
  int i, j, inicio, final;
  char cadena[100] = "3 * 5 + (9 - 2) + 5", auxiliar[100];
 
  for (i = 0; cadena[i]; i++){
     if (cadena[i] == '(')
        inicio = i;
     if (cadena[i] == ')') {
        final = i;
        break;
     }
  }
 
  for (i = inicio + 1, j = 0; i < final; i++, j++)
     auxiliar[j] = cadena[i];
  auxiliar[j] = '\0';
 
  for (i = inicio; i <= final; i++)
     cadena[i] = ' ';
 
  printf("auxiliar = \"%s\", cadena = \"%s\"\n", auxiliar, cadena);
 
  return 0;
}


----

Editado: para obtener la subcadena delimitada por paréntesis mediante strchr basta con dos llamadas la primera buscando '(' y la segunda ')'. Por ejemplo:
#include <stdio.h>
#include <string.h>

int main(void)
{
   char *s = "3 * 5 + (9 - 2) + 5";
   char *p;
   char *q;
   
   if ((p = strchr(s, '(')) && (q = strchr(p, ')')))
      printf("%.*s\n", (int) (q - p + 1), p);
   
   return 0;
}

Eso para imprimir la subcadena en la salida estándar, para almacenarla en un array basta con sustituir printf por sprintf.

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

NOB2014

Hola a todos.
rir3760 lo estoy haciendo de esta manera porque lo tuyo me gusta muchísimo porque es más conciso, pero no logro todavía implementarlo, lo que me trae ahora es que alguien me diga cómo puedo poner el operador en una variable como la operador luego lo pondré en un arreglo para con un if establecer el correspondiente.-         

Saludos.
Daniel



#include <stdio.h>
#include <stdlib.h>

int main(void){
int i, j, inicio, final, resultado = 0;
char cadena[100] = "3 * 5 + (9 + 2) + 5", auxiliar[100] = {'\0'}, auxUno[2] = {'\0'}, auxDos[2] = {'\0'}, operador[2] = {'\0'};

for (i = 0; cadena[i]; i++){
if (cadena[i] == '(')
inicio = i;
if (cadena[i] == ')') {
final = i;
break;
}
}

for (i = inicio + 1, j = 0; i < final; i++, j++)
auxiliar[j] = cadena[i];

auxiliar[j] = '\0';
operador[0] = auxiliar[2]; operador[1] = '\0';
auxUno[0] = auxiliar[0]; auxUno[1] = '\0';
auxDos[0] = auxiliar[4]; auxDos[1] = '\0';
resultado = atoi(auxUno) - atoi(auxDos);
printf("\n %d", resultado);

for (i = inicio; i <= final; i++)
cadena[i] = ' ';


return 0;
}
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor y cuando lo abrazas dejan de causar dolor.-

leosansan

#5
Cita de: NOB2014 en  7 Abril 2014, 15:42 PM
...................................................
...........lo que me trae ahora es que alguien me diga cómo puedo poner el operador en una variable como la operador luego lo pondré en un arreglo para con un if establecer el correspondiente.-    ......................... ....................


Lo primero es lo primero y es ni más ni menos que eliminar de la subcadena auxiliar los espacios en blanco, que luego la lían parda. Esto lo consigues con una pequeña modificación en tu código:

Código (cpp) [Seleccionar]
for (i = inicio + 1, j = 0; i < final; i++)
   if (cadena[i]!=' '){
   auxiliar[j] = cadena[i];
   j++;
   }
auxiliar[j] = '\0';
 printf("\n%s\n", auxiliar);


Lo segundo es que a priori estableces que los números se compongan de un solo dígito, cuando podrían estar formados por varios dígitos y ya te fastidiarían las cuentas de dónde está el signo,etc. Esto lo puedes arreglar con:

Código (cpp) [Seleccionar]
i=0;
 for (j=0,k=0;auxiliar[j];j++){
   if (isdigit(auxiliar[j])){
     aux[k][i]=auxiliar[j];
     i++;
   }
   if (!isdigit(auxiliar[j])){
     op=auxiliar[j];
     aux[k][i]='\0';
     i=0,k++;
   }
 }
 aux[k][i]='\0';


Y lo del operador, que lo pillas en el trozo de código anterior en op, basta con usar una variable char op que guarde el tipo de operación y luego en un switch seleccionarla de forma automática. Algo como:

Código (cpp) [Seleccionar]
switch(op){
   case'+':resultado = atoi(aux[0]) + atoi(aux[1]);
   break;
   case'-':resultado = atoi(aux[0]) - atoi(aux[1]);
   break;
   case'*':resultado = atoi(aux[0]) * atoi(aux[1]);
   break;
   case'/':resultado = atoi(aux[0]) / atoi(aux[1]);
   break;
   /******* y mas *******/
 }
 printf("\nRESULTADO: %d", resultado);


Y ya tendrías una salida como esta, con la segunda linea de código:

Código (cpp) [Seleccionar]
char cadena[100] = "3 * 5 + (1 5 * 2 5  0) + 5", auxiliar[100] = {'\0'}, aux[10][10] = {'\0'}, op;

Citar

15*250

RESULTADO: 3750



Queda mucho por hacer, por ejemplo que exista más de  una operación, que los números sean decimales, etc. Pero todo se va andando despacito.

Salu2!.

NOB2014

Hola leo.
Que puedo decir del trabajo que te tomaste para corregir casi todo el código y además documentarlo, muchas pero muchas gracias.-
Me pongo de inmediato a tratar de implementarlo y luego te/les haré consulta de las cosas que me queden dudas.-

CitarUna sugerencia para Eternal Idol, me parece que sería conveniente que cuando se modifica el post se obligue a poner una pequeña descripción del motivo, leí a primera hora de la mañana(Argentina) lo que posteo leo y luego encuentro "Última modificación: Hoy a las 16:57 por leosansan" y me interesaría saber que modificó, creo que me/nos ayudaría a comprender  más fácilmente el contenido del mismo, sólo una sugerencia que tal vez ni llegues a leer.-

Saludos.
Daniel
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor y cuando lo abrazas dejan de causar dolor.-

leosansan

#7
Citar
Una sugerencia para Eternal Idol, me parece que sería conveniente que cuando se modifica el post se obligue a poner una pequeña descripción del motivo, leí a primera hora de la mañana(Argentina) lo que posteo leo y luego encuentro "Última modificación: Hoy a las 16:57 por leosansan" y me interesaría saber que modificó, creo que me/nos ayudaría a comprender  más fácilmente el contenido del mismo, sólo una sugerencia que tal vez ni llegues a leer.-

Aclaro la modificación.

En el primer código en borrador que hice no elimine los espacios en blanco de la cadena auxiliar por lo que aparecía la línea:


Código (cpp) [Seleccionar]
if (!isdigit(auxiliar[j]) && auxiliar[j]!=' ' ){

Me dí cuenta que los espacios en blanco engorrinaban el código y surgió el código que colgué donde los eliminaba previamente de la cadena auxiliar. Pero con las prisas se me olvidó que entonces el:

Código (cpp) [Seleccionar]
&& auxiliar[j]!=' '

Estaba de más, no mal, de más. Al verlo por la tarde me dí cuenta y lo corregí eliminando y dejando la línea como:

Código (cpp) [Seleccionar]
if (!isdigit(auxiliar[j])){

Una corrección menor por lo que no puse el mensaje de EDITADO que pongo cuando cambio algo sustancial. Yo al menos hago eso, para que quede constancia.

Espero haber aclarado las posibles dudas que planteaban en el comentario.

Salu2!.


EDITO: Además del error de un nuevo post, sorry, sorry, la mayor parte de las ediciones son meras correcciones ortográficas, como la de ahora en que tenía puesto dnde en lugar de donde.

Eternal Idol

NOB2014: yo lo leo pero soy un moderador unicamente, si queres plantealo al STAFF en el subforo de "Sugerencias y dudas sobre el Foro". Igual calcula que si obligas a poner un texto, siempre se puede poner algo inutil igual (como "editar por editar"), con lo cual la opcion y la obligacion terminan siendo lo mismo.
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón

NOB2014

Hola a todos.-
Leo, espero que no me hayas mal interpretado, lo mío era tan solo una sugerencia y te tomé como  referencia porqué fue una idea del momento, lo que decís Eternal es muy cierto pero a alguien como Uds. que hacen una tarea tan loable e impagable disponiendo tanto tiempo al servicio de los demás sin más no creo que se les cruce por la cabeza el hecho  de mentir, no por lo menos en este ámbito.-       

Saludos.
Daniel
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor y cuando lo abrazas dejan de causar dolor.-