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)


  Mostrar Mensajes
Páginas: [1]
1  Programación / Programación C/C++ / Re: Programa en C : ¿Por qué me salen estos símbolos? en: 9 Junio 2012, 17:31 pm
Muchísimas gracias man, ya me ha funcionado :) Me habéis salvado la vida.

Gracias!
2  Programación / Programación C/C++ / Re: Programa en C : ¿Por qué me salen estos símbolos? en: 9 Junio 2012, 17:15 pm
:O Si, lo había entendido mal, gracias. Acabo de usar esa instrucción pero al compilar me da error....Qué librería debo de incluir para usar esa función?
3  Programación / Programación C/C++ / Re: Programa en C : ¿Por qué me salen estos símbolos? en: 9 Junio 2012, 16:49 pm
Pero el inconveniente en este caso es de que al inicializar en "cero" la estructura, entonces ya no me cumpliría la condición posterior.
4  Programación / Programación C/C++ / Re: Programa en C : ¿Por qué me salen estos símbolos? en: 9 Junio 2012, 16:32 pm
Pues dado a que ese "*a" es una estructura, por ejemplo a qué lo podría igualar?? Ya qué lo podría inicializar en NULL, pero con eso ya no cumpliría la condición que le sucede a esa instrucción.

También hasta donde tengo entendido, al haber usado "malloc" para asignar memoria, no debería de haber problema.
5  Programación / Programación C/C++ / Programa en C : ¿Por qué me salen estos símbolos? en: 9 Junio 2012, 04:42 am
Hola. Tengo el siguiente problema:
He creado este programa que es un Árbol de Expresión, y pues bueno, lee la expresión infija, luego la guarda en el árbol, luego realizando un recorrido en orden muestra el resultado de la expresión guardada. Pero mi problema es de que este programa lo codifiqué en Ubuntu, y ahi me corre bien luego de compilado, pero luego al probarlo en Windows, el programa me compila bien y todo, pero me muestra unos códigos extraños y además hace que la respuesta de la expresión sea errónea.
Aquí les muestro como se ve en Ubuntu:



Aquí les muestro lo que me saca en Windows:


Espero me puedan ayudar ya que es un royecto que me puede salvar la vida :S
Acá queda el código y gracias de antemano.

PD: En Ubuntu el IDE que usé para programar fue el Code::Blocks, el mismo utilicé en Windows para compilar el código.

Código
  1. /*El siguiente programa lee una expresión matemática, muestra los diferentes recorridos de la
  2. expresión (EnOrden, PreOrden y PostOrden) y luego evalúa dicha expresión mostrando el resultado final. */
  3.  
  4. #include<stdio.h>
  5. #include<conio.h>
  6. #include<stdlib.h>
  7. #include<math.h>
  8.  
  9. typedef char tipoDato;
  10.  
  11. struct nodo{
  12. tipoDato dato;
  13. struct nodo *izquierdo;
  14. struct nodo *derecho;
  15. };
  16. typedef struct nodo *Arbol;
  17.  
  18. void insExp(Arbol *a, tipoDato dato);
  19. void InOrden(Arbol a);
  20. void postOrden(Arbol a);
  21. void preOrden(Arbol a);
  22. int evaluar(Arbol a);
  23. int operar(int, int, char);
  24.  
  25. //Inicio del módulo principal.
  26. int main(){
  27. tipoDato exp[100]; int i=0,resul;
  28. Arbol raiz=NULL;
  29. printf("\nIngrese la expresion: ");
  30. while(exp[i]){
  31.     insExp(&raiz,exp[i]);
  32.     ++i;
  33. }
  34. printf("\n\nRECORRIDO POSTORDEN:\n");
  35. preOrden(raiz);
  36. printf("\n\nRECORRIDO INORDEN:\n");
  37. InOrden(raiz);
  38. printf("\n\nRECORRIDO POSTORDEN:\n");
  39. postOrden(raiz);
  40. resul=evaluar(raiz);
  41. printf("\n\nRESULTADO DE EXPRESION: %d\n\n",resul);
  42. for(i=0;i<=60;i++) printf("*");
  43. return 0;
  44. //Fin del módulo principal.
  45. }
  46.  
  47. void preOrden(Arbol a){
  48.    if(a!=NULL){
  49.    printf("%c",a->dato);
  50.    preOrden(a->izquierdo);
  51.    preOrden(a->derecho);
  52.    }
  53. }
  54.  
  55. void postOrden(Arbol a){
  56.    if(a!=NULL){
  57.    postOrden(a->izquierdo);
  58.    postOrden(a->derecho);
  59.    printf("%c",a->dato);
  60.    }
  61. }
  62.  
  63. void InOrden(Arbol a){
  64.    if(a!=NULL){
  65.    InOrden(a->izquierdo);
  66.    printf("%c",a->dato);
  67.    InOrden(a->derecho);
  68.    }
  69. }
  70. int evaluar(Arbol a){
  71.    int ope1, ope2;
  72.    if(a==NULL) return 0;
  73.    else if(a->izquierdo==NULL && a->derecho==NULL) return(a->dato-48);
  74.    else{
  75.        ope1=evaluar(a->izquierdo);
  76.        ope2=evaluar(a->derecho);
  77.        return(operar(ope1,ope2,a->dato));
  78.        }
  79. }
  80. int operar(int x, int y, char z){
  81.    int res;
  82.  
  83.    switch(z){
  84.    case '+':
  85.    res=x+y;
  86.    break;
  87.    case '-':
  88.    res=x-y;
  89.    break;
  90.    case '*':
  91.    res=x*y;
  92.    break;
  93.    case '^':
  94.    return pow(x,y);
  95.    break;
  96.    case '/':
  97.     if(y!=0)
  98. res=x/y;
  99. else
  100. puts("ERROR! division entre cero");
  101.     break;
  102.    }
  103.    return res;
  104. }
  105. //Inserción para Árbol de Expresión.
  106. void insExp(Arbol *a, tipoDato dato){
  107.    if(*a==NULL){
  108.       *a=malloc(sizeof(struct nodo));
  109.       if(*a!=NULL){
  110.           if(dato!='('){
  111.               (*a)->dato=dato;
  112.           }
  113.        (*a)->izquierdo=(*a)->derecho=NULL;
  114.       }
  115.       else printf("\nNo se pudo asignar memoria...CERRANDO APLICACION\n");
  116.    }
  117.    else{
  118.        if(dato=='('){
  119.           if((*a)->izquierdo==NULL)
  120.           insExp(&((*a)->izquierdo),dato);
  121.           else
  122.           insExp(&((*a)->derecho),dato);
  123.        }
  124.        else if(dato>=48 && dato<=57){
  125.            if((*a)->dato=='\0'){
  126.                insExp(&((*a)->izquierdo),dato);
  127.            }
  128.            else
  129.            insExp(&((*a)->derecho),dato);
  130.        }
  131.        if(dato=='*' || dato=='+' || dato=='-' || dato=='/' || dato=='^'){
  132.            if((*a)->dato=='\0' && (*a)->derecho==NULL){
  133.                if((*a)->izquierdo->dato=='\0')
  134.                insExp(&((*a)->izquierdo),dato);
  135.                else
  136.                (*a)->dato=dato;
  137.            }
  138.            else{
  139.                if((*a)->izquierdo!=NULL && (*a)->derecho!=NULL){
  140.                    if((*a)->derecho->dato=='\0')
  141.                    insExp(&((*a)->derecho),dato);
  142.                    else
  143.                    (*a)->dato=dato;
  144.                }
  145.            }
  146.        }
  147.    }
  148. }
Páginas: [1]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines