Autor
|
Tema: warnings (Leído 6,878 veces)
|
m@o_614
Desconectado
Mensajes: 389
|
|
warnings
« en: 21 Diciembre 2012, 01:08 am » |
|
saludos tengo el siguiente código de una lista simplemente enlazada, pero el problema es que me aparece un warning que dice: return makes pointer from integer without a cast #include <stdio.h> #include <stdlib.h> typedef struct nodo { int dato; struct nodo*sig; }NODO; NODO* crear_nodo(int x); void insertar_cabeza(NODO **cabeza,int x); NODO* buscar_elemento(NODO *cabeza); int main() { int i,num,x; NODO *cabeza,*ptr; cabeza = NULL; printf("Cuantos elementos quieres?\n"); printf("Lista Simplemente Ligada!\n"); for(i=0;i<num;i++) { printf("Dame el elemento %d\n",i +1); insertar_cabeza(&cabeza,x); } for(ptr=cabeza;ptr!=NULL;ptr=ptr->sig) buscar_elemento(cabeza); return 0; } NODO* crear_nodo(int x) { NODO *p; p = (NODO *)malloc(sizeof(NODO )); p->dato = x; p->sig = NULL; return p; } void insertar_cabeza(NODO **cabeza,int x) { NODO *nuevo; nuevo = crear_nodo(x); nuevo->sig = *cabeza; *cabeza = nuevo; } NODO* buscar_elemento(NODO *cabeza) { int elemento,encontro=0; NODO *indice; printf("Buscar elemento\n\n"); printf("Cual elemento quieres buscar?\n"); for(indice=cabeza;indice!=NULL;indice=indice->sig) { if(indice->dato==elemento) encontro=1; else encontro=0; } if(encontro) return indice->dato; else return 0; }
de antemano gracias
|
|
|
En línea
|
|
|
|
naderST
|
|
Re: warnings
« Respuesta #1 en: 21 Diciembre 2012, 01:15 am » |
|
El warning es porque en tu caso buscar_elemento debe retornar un apuntador a NODO (NODO*) y tu estás retornando un entero. if(encontro) return indice->dato; else return 0;
|
|
|
En línea
|
|
|
|
dato000
Desconectado
Mensajes: 3.034
|
|
Re: warnings
« Respuesta #2 en: 21 Diciembre 2012, 11:53 am » |
|
pero el warning no afecta el funcionamiento del programa, deberia retornar NULL entonces??
|
|
|
En línea
|
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
|
Re: warnings
« Respuesta #3 en: 21 Diciembre 2012, 15:56 pm » |
|
pero el warning no afecta el funcionamiento del programa, deberia retornar NULL entonces??
Si.
|
|
|
En línea
|
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
|
|
|
m@o_614
Desconectado
Mensajes: 389
|
|
Re: warnings
« Respuesta #4 en: 22 Diciembre 2012, 01:53 am » |
|
muchas gracias por sus respuestas, ahora ya no me aparece ese warning pero como ya le agregue la función de eliminar_elemento (en esta metí la función de buscar) pero no me hace lo que le pido #include <stdio.h> #include <stdlib.h> typedef struct nodo { int dato; struct nodo*sig; }NODO; NODO* crear_nodo(int x); void insertar_cabeza(NODO **cabeza,int x); void eliminar_elemento(NODO **cabeza); int main() { int i,num,x; NODO *cabeza,*ptr; cabeza = NULL; printf("Cuantos elementos quieres?\n"); printf("Lista Simplemente Ligada!\n\n"); for(i=0;i<num;i++) { printf("Dame el elemento %d\n",i +1); insertar_cabeza(&cabeza,x); } for(ptr=cabeza;ptr!=NULL;ptr=ptr->sig) eliminar_elemento(&cabeza); for(ptr=cabeza;ptr!=NULL;ptr=ptr->sig) return 0; } NODO* crear_nodo(int x) { NODO *p; p = (NODO *)malloc(sizeof(NODO )); p->dato = x; p->sig = NULL; return p; } void insertar_cabeza(NODO **cabeza,int x) { NODO *nuevo; nuevo = crear_nodo(x); nuevo->sig = *cabeza; *cabeza = nuevo; } void eliminar_elemento(NODO **cabeza) { int n; NODO *actual,*anterior; anterior=NULL; printf("Dame el elemento a eliminar\n"); for(actual=*cabeza;actual!=NULL;actual=actual->sig) { if(actual->dato==n) { anterior = actual->sig; actual = anterior; } } }
estos punteros por qué son tan difíciles??
|
|
|
En línea
|
|
|
|
twins
Desconectado
Mensajes: 54
|
|
Re: warnings
« Respuesta #5 en: 22 Diciembre 2012, 02:24 am » |
|
Hola pues te explico para eliminar un nodo que este en una posicion distinta del inicio o final necesitas usar dos punteros para poder hacer los enlaces en este caso yo solo modifique la funsion eliminar_elemento tu puedes revisar y ver cuales fueron los cambios cordiales saludos #include <stdio.h> #include <stdlib.h> typedef struct nodo{ int dato; struct nodo *sig; }NODO; NODO* crear_nodo(int x); void insertar_cabeza(NODO **cabeza,int x); void eliminar_elemento(NODO **cabeza); int main(void){ int i,num,x; NODO *cabeza,*ptr; cabeza = NULL; printf("Cuantos elementos quieres?\n"); printf("Lista Simplemente Ligada!\n\n"); for(i=0;i<num;i++){ printf("Dame el elemento %d\n",i +1); insertar_cabeza(&cabeza,x); } for(ptr=cabeza;ptr!=NULL;ptr=ptr->sig) eliminar_elemento(&cabeza); for(ptr=cabeza;ptr!=NULL;ptr=ptr->sig) return 0; } NODO* crear_nodo(int x){ NODO *p; p = (NODO *)malloc(sizeof(NODO )); p->dato = x; p->sig = NULL; return p; } void insertar_cabeza(NODO **cabeza,int x){ NODO *nuevo; nuevo = crear_nodo(x); nuevo->sig = *cabeza; *cabeza = nuevo; } void eliminar_elemento(NODO **cabeza){ int n; NODO *aux1=*cabeza,*aux2=aux1; printf("Dame el elemento a eliminar\n"); while(aux2->dato!=n){ aux1=aux2; aux2=aux2->sig; } aux1->sig=aux2->sig; }
|
|
|
En línea
|
|
|
|
rir3760
Desconectado
Mensajes: 1.639
|
|
Re: warnings
« Respuesta #6 en: 23 Diciembre 2012, 03:09 am » |
|
ahora ya no me aparece ese warning pero como ya le agregue la función de eliminar_elemento (en esta metí la función de buscar) pero no me hace lo que le pido Como ya te comentaron: A) Si el nodo a eliminar es el primero debes utilizar el parámetro de la función para así afectar la variable "cabeza" de la función main. B) Para cualquier otro nodo solo hay que actualizar el campo "sig" del nodo anterior. Para eliminar un nodo de una lista no es necesario utilizar variables auxiliares (en el bucle), en su lugar se trabaja directamente con el parámetro (y sirve para practicar el tema): void eliminar_elemento(NODO **p) { NODO *aux; int dato; puts("Dame el elemento a eliminar:"); while (*p != NULL && (*p)->dato != dato) p = &(*p)->sig; if (*p != NULL){ aux = *p; *p = (*p)->sig; } }
Un saludo
|
|
|
En línea
|
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
|
|
|
durasno
Desconectado
Mensajes: 373
|
|
Re: warnings
« Respuesta #7 en: 23 Diciembre 2012, 06:48 am » |
|
Hola! muy bueno el aporte rir3760, la verdad me costo entenderlo; trabajar directamente con el puntero a puntero Saludos
|
|
|
En línea
|
Ahorrate una pregunta, lee el man
|
|
|
m@o_614
Desconectado
Mensajes: 389
|
|
Re: warnings
« Respuesta #8 en: 28 Diciembre 2012, 03:22 am » |
|
Muchas gracias por sus respuestas Una última pregunta porque cuando le ingreso por ejemplo los números 5,18,67,80 me los imprime al revés 80, 67,18 y 5 no se supone que el puntero *cabeza siempre apunta al inicio de la lista?? ¿por qué la imprime así? gracias
|
|
|
En línea
|
|
|
|
twins
Desconectado
Mensajes: 54
|
|
Re: warnings
« Respuesta #9 en: 28 Diciembre 2012, 16:37 pm » |
|
Eso es porque los nodos los estas ingresando al inicio de la lista por ejemplo si ingresas el 1 y despues el 2, en este caso el 2 quedara a la izquierda del 1 es decir 2,1 y tu puntero cabeza apunta al segundo nodo recien ingresado, en este caso el 2, por lo tanto cuando imprimes, imprimes de izquierda a derecha ose 2,1. si quieres que los nodos sea impresos segun el orden en que fueron ingresados tendras que modificar la funcion insertar_cabeza.
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Fase test: Mi intranet :: Matriculas - notas - pagos - etc :: Comentar Warnings
Desarrollo Web
|
Hadess_inf
|
5
|
3,220
|
4 Julio 2010, 10:35 am
por Joker
|
|
|
Warnings en tratamiento de ficheros con C++ Builder XE
Programación C/C++
|
mario_tko
|
1
|
3,118
|
15 Noviembre 2011, 16:01 pm
por do-while
|
|
|
Warnings en gcc -Wall
Programación C/C++
|
soyloqbuskas
|
3
|
3,866
|
4 Abril 2012, 03:51 am
por Beakman
|
|
|
warnings en compilacion
Programación C/C++
|
ccsponcer3
|
3
|
2,985
|
5 Junio 2016, 18:03 pm
por HardForo
|
|
|
Implementar warnings en compilador
Programación General
|
Adri124
|
0
|
1,725
|
28 Junio 2016, 21:16 pm
por Adri124
|
|