Autor
|
Tema: Duda EOF (Leído 2,372 veces)
|
pedroedlp
Desconectado
Mensajes: 17
|
bueno, basicamente no entiendo que es lo que hace EOF, les dejo ete programa que en teoria imprime la linea de entrada mas larga, pero yo ejecuto el programa y no hace nada, solo espera q le ingrese datos por teclado, yo creo que es por algo del EOF, que siempre da verdadero el while. #include <stdio.h>
#define MAXLINE 1000
int getline(char line[], int maxline);
void copy(char to[], char from[]);
main(){
int len, max; char line[MAXLINE]; char longest[MAXLINE];
max=0;
while ((len=getline(line, MAXLINE) > 0 )){ if(len > max){ max = len; copy(longest, line); } }
if(max > 0){ printf("%s", longest); }
return 0;
}
int getline(char s[], int lim){
int c, i;
for(i=0; i<lim-1 && (c=getchar()) != EOF && c != '\n'; ++i) s[i] = c; if(c == '\n'){ s[i] = c; ++i; } s[i] = '\0';
return i;
}
void copy(char to[], char from[]){
int i;
i=0; while((to[i] = from[i]) != '\0'){ ++i; } }
|
|
|
En línea
|
|
|
|
rir3760
Desconectado
Mensajes: 1.639
|
basicamente no entiendo que es lo que hace EOF Es una macro definida en <stdio.h> con un valor menor que cero (usualmente -1) y es el valor de retorno de algunas funciones de la biblioteca estándar (por ejemplo getchar) para indicar que la operación de lectura fallo al alcanzar el final del archivo. les dejo ete programa que en teoria imprime la linea de entrada mas larga Es uno de los ejemplos del libro "The C programming language". pero yo ejecuto el programa y no hace nada, solo espera q le ingrese datos por teclado, yo creo que es por algo del EOF, que siempre da verdadero el while. Es el comportamiento normal. Como se procesa la entrada estándar debes introducir varias lineas y a continuación la señal de fin de archivo ({CONTROL} + Z en MS Windows y {CONTROL} + d en Linux). Solo entonces el programa imprimirá la linea mas larga. 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
|
|
|
pedroedlp
Desconectado
Mensajes: 17
|
Es una macro definida en <stdio.h> con un valor menor que cero (usualmente -1) y es el valor de retorno de algunas funciones de la biblioteca estándar (por ejemplo getchar) para indicar que la operación de lectura fallo al alcanzar el final del archivo. Es uno de los ejemplos del libro "The C programming language". Es el comportamiento normal. Como se procesa la entrada estándar debes introducir varias lineas y a continuación la señal de fin de archivo ({CONTROL} + Z en MS Windows y {CONTROL} + d en Linux). Solo entonces el programa imprimirá la linea mas larga.
Un saludo
yo apreto ctrl + z y no pasa nada, me aparece el ^Z
|
|
|
En línea
|
|
|
|
rir3760
Desconectado
Mensajes: 1.639
|
Introduces la combinación de teclas y a continuación presionas la tecla {ENTER}.
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
|
|
|
pedroedlp
Desconectado
Mensajes: 17
|
Introduces la combinación de teclas y a continuación presionas la tecla {ENTER}.
Un saludo
perdon, pero no me funciona
|
|
|
En línea
|
|
|
|
leosansan
Desconectado
Mensajes: 1.314
|
perdon, pero no me funciona
Funcionar, lo que se dice funcionar, funciona. Otra cosa es que los resultados sean los previstos, que no lo son.
Además de declarar main como int inicializo max a cero, que no lo estaba y la salida poniendo un printf justito después del while:printf("len=%d \n", len);
123 len=1 12345 len=1 1234567 len=1 12 len=1 ^Z 123
Process returned 0 (0x0)
Al parecer la variable len no pilla el retorno de la función, al menos dentro del while ¿?.
En cambio si la sacamos del while funciona perfecto. Lo he ajustado para que al entrar un enter solitario, sin nada en la linea, se acabe la ejecución sin así tener que recurrir al CTR-Z:123 len=4 max=4 12345 len=6 max=6 123456789 len=10 max=10 3215 len=5 32 len=3 1 len=2 <==ESTO ES UN ENTER SOLITARIO len=1
Cadena mas larga: 123456789
Process returned 0 (0x0)
#include <stdio.h> #define MAXLINE 1000 int getline(char line[], int maxline); void copy(char to[], char from[]); int main(){ int len=2, max=0; char line[MAXLINE]; char longest[MAXLINE]; while (len>1){ len=getline(line, MAXLINE); printf("len=%d ", len); if(len > max){ max = len; printf("max=%d\n", max); copy(longest, line); } } if(max > 0) printf("\nCadena mas larga: %s", longest); return 0; } int getline(char s[], int lim){ int c, i; for(i=0; i<lim-1 && (c=getchar()) != EOF && c != '\n'; ++i) s[i] = c; if(c == '\n'){ s[i] = c; ++i; } s[i] = '\0'; printf("%d\n", i); return i; } void copy(char to[], char from[]){ int i; i=0; while((to[i] = from[i]) != '\0'){ ++i; } }
Aún no le encuentro justificación al comportamiento de len dentro del while. ¡¡¡¡ Saluditos! ..... !!!!
|
|
|
En línea
|
|
|
|
pedroedlp
Desconectado
Mensajes: 17
|
Funcionar, lo que se dice funcionar, funciona. Otra cosa es que los resultados sean los previstos, que no lo son.
Además de declarar main como int inicializo max a cero, que no lo estaba y la salida poniendo un printf justito después del while:printf("len=%d \n", len);
Al parecer la variable len no pilla el retorno de la función, al menos dentro del while ¿?.
En cambio si la sacamos del while funciona perfecto. Lo he ajustado para que al entrar un enter solitario, sin nada en la linea, se acabe la ejecución sin así tener que recurrir al CTR-Z:#include <stdio.h> #define MAXLINE 1000 int getline(char line[], int maxline); void copy(char to[], char from[]); int main(){ int len=2, max=0; char line[MAXLINE]; char longest[MAXLINE]; while (len>1){ len=getline(line, MAXLINE); printf("len=%d ", len); if(len > max){ max = len; printf("max=%d\n", max); copy(longest, line); } } if(max > 0) printf("\nCadena mas larga: %s", longest); return 0; } int getline(char s[], int lim){ int c, i; for(i=0; i<lim-1 && (c=getchar()) != EOF && c != '\n'; ++i) s[i] = c; if(c == '\n'){ s[i] = c; ++i; } s[i] = '\0'; printf("%d\n", i); return i; } void copy(char to[], char from[]){ int i; i=0; while((to[i] = from[i]) != '\0'){ ++i; } }
Aún no le encuentro justificación al comportamiento de len dentro del while. ¡¡¡¡ Saluditos! ..... !!!! muchas gracias
|
|
|
En línea
|
|
|
|
leosansan
Desconectado
Mensajes: 1.314
|
muchas gracias
De nada campeón. Y espero que alguien más lucido nos explique el por qué del comportamiento anómalo de len en el while.¡¡¡¡ Saluditos! ..... !!!!
|
|
|
En línea
|
|
|
|
rir3760
Desconectado
Mensajes: 1.639
|
Funcionar, lo que se dice funcionar, funciona. Otra cosa es que los resultados sean los previstos, que no lo son.
Además de declarar main como int inicializo max a cero, que no lo estaba A la variable "max" se le asigna el valor cero justo antes del bucle, con ella no hay problema. El error se encuentra en el bucle while, al copiar el programa se colocaron mal los paréntesis: while ((len = getline(line, MAXLINE) > 0 )) ...
Para que funcione correctamente basta con cambiarlo a: /* Primero se asigna el resultado de getline a len y solo entonces se compara */ while ((len = getline(line, MAXLINE)) > 0 ) ...
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
|
|
|
|
|