Ciao a tutti! avrei bisogno di un piccolo aiuto.. devo creare un programma che scriva un file con estensione .world in cui sono contenute le 100 parole più frequenti (per parola si intende una successione di caratteri comprese tra due spazi) che saranno prese da un file .txt in input!
Il mio problema sta nel fatto che nel file .world vengono considerati anche gli spazi, mentre non dovrebbe farlo!
vi posto tutto il codice, ma il mio problema dovrebbe trovarsi nel while(lettera != EOF) {...}
grazie a tutti
codice:
#include <stdio.h> //Direttive al pre processore che ci permettono di includere
#include <string.h> //gli haeder file,relativi a librerie standar.
#include <stdlib.h>
#include <limits.h>
#include <assert.h>
// definizione della funzione ASSERT() con stampa di un messaggio di errore
#define ASSERT( condizionedaverificare, cosafare ) { if ( !(condizionedaverificare) ) { printf cosafare; printf("\n"); assert( condizionedaverificare ); } }
struct lista{ //Dichiarazione della lista usata dalla funzione aggiuntiva
char parola[257]; //Dichiarazione di un array di lunghezza massima 1024 adibito a contenere la parola
int frequenza; //Dichiarazione di una varibile adibita a contenere la frequenza della parola
struct lista *next; //Dichiarazione di un puntatore per lo spostamento all'interno della lista
};
void funzioneAusiliaria(char *nomeDelFile)
{
/**
*Il primo passo dell'algoritmo della funzione conteggio_cento prevede la dichiarazione di tutte le variabili che occorrono per il suo svolgimento e infine la creazione del nuovo
*file dove successivamente verranno inserite le parole con le successive frequenze.
*/
FILE *fileTesto=NULL,*fpw=NULL ;
char *centoParole;
char bufferLettura[257];
char lettera;
int contaLettere = 0;
int contaParole=0;
struct lista *nuovo;
struct lista *testa;
struct lista *temp, *temp2, *prev;
testa=NULL;
centoParole = (char*)malloc(sizeof(char)*(strlen(nomeDelFile)+7));
strncpy(centoParole,nomeDelFile,strlen(nomeDelFile));
strncat(centoParole,".world\0",7);
printf("\nIl nome del file creato dalla funzione cento e': %s\n",centoParole);
fflush(stdout);
fileTesto=fopen(nomeDelFile,"r"); //apertura del file di testo in modalità lettura
ASSERT((fileTesto!=NULL),("\nErrore nell'apertura del file di testo!\n"));
//controllo se il fileTesto è vuoto
lettera=fgetc(fileTesto);
if(feof(fileTesto))
{
printf("\nFile vuoto!");
fclose(fileTesto);
exit(1);
}
while(lettera != EOF)
{
if (lettera!=' ') {
if (contaLettere < 256) {
bufferLettura[contaLettere]=lettera;
}
contaLettere++;
}
else {
if (contaLettere <= 256)
{ //funzione di inserimento in lista
bufferLettura[contaLettere]='\0';
prev = NULL;
temp = testa;
while(temp != NULL && strcmp(bufferLettura,temp->parola) != 0)
{
prev = temp;
temp = temp->next; //Incremento il puntatore per avanzare nella scansione della lista
}
if (temp == NULL)
{
nuovo=(struct lista*)malloc(sizeof(struct lista)); //Allocazione dinamica della memoria di una nuova cella della lista tramite la funzione malloc
strncpy(nuovo->parola,bufferLettura,contaLettere);
nuovo->frequenza=1; //Impostazione della frequenza della parola a 1
nuovo->next = NULL;
if (testa != NULL)
prev->next = nuovo;
else
testa = nuovo;
}
else
temp->frequenza++;
}
bufferLettura[0]='\0';
contaLettere=0;
}
lettera=fgetc(fileTesto);
}
if (contaLettere <= 256) //inserisci in lista
{
//funzione di inserimento in lista
prev = NULL;
temp = testa;
while(temp != NULL && strcmp(bufferLettura,temp->parola) != 0)
{
prev = temp;
temp = temp->next; //Incremento il puntatore per avanzare nella scansione della lista
}
if (temp == NULL)
{
nuovo=(struct lista*)malloc(sizeof(struct lista)); //Allocazione dinamica della memoria di una nuova cella della lista tramite la funzione malloc
strncpy(nuovo->parola,bufferLettura,contaLettere);
nuovo->frequenza=1; //Impostazione della frequenza della parola a 1
nuovo->next = NULL;
if (testa != NULL)
prev->next = nuovo;
else
testa = nuovo;
}
else
temp->frequenza++;
}
//ordinamento lista
printf("\n ordinamento lista");
temp = testa;
testa = NULL;
while (temp != NULL)
{
temp2 = testa;
prev = NULL;
while (temp2 != NULL && temp->frequenza < temp2->frequenza)
{
prev = temp2;
temp2 = temp2->next;
}
if (prev != NULL)
prev->next = temp;
else
testa = temp;
prev = temp->next;
temp->next = temp2;
temp = prev;
}
printf("\n Stampa su file");
//scrittura file 100 parole
fpw=fopen(centoParole,"w");
//utilizziamo prev per poter controllare la frequenza della centesima parola e delle successive.se hanno la stessa frequenza le stampiamo
temp = testa;
prev=temp;
while (temp != NULL && contaParole<100)
{
fprintf(fpw,"%d %s \r\n", temp->frequenza, temp->parola);
contaParole++;
prev=temp;
temp = temp->next;
}
//fare controllo su temp
if(temp == NULL)
{
fclose(fpw);
fclose(fileTesto);
exit(0);
}
while (prev->frequenza == temp->frequenza)
{
fprintf(fpw,"%d %s \r\n", temp->frequenza, temp->parola);
prev=temp;
temp = temp->next;
}
//printf("\n(5)\n");
fclose(fpw);
fclose(fileTesto);
}
int main(int argc, char *argv[])
{
char *nomeDelFile; //puntatore al nome del file da comprimere o decomprimere
int dimensioneNomeFile=0; //conterrà la dimensione del nome del file da comprimere o decomprimere
if(argc!=2) //controllo sul numero di parametri per far partire il programma che devono essere: <nome programma> <nome file>
{
printf("\nErrore!Indicare il nome del file da comprimere o da decomprimere\n");
exit(1);
}
nomeDelFile=argv[1]; //copio il contenuto di argv[1] che contiene il nome del file da comprimere/decomprimere
dimensioneNomeFile=strlen(argv[1]); //misuro la lunghezza del nome del file
//identifico se il file è da comprimere o decomprimere,analizzando la sua estensione
if((nomeDelFile[dimensioneNomeFile-1]=='t')&&(nomeDelFile[dimensioneNomeFile-2]=='x')&&(nomeDelFile[dimensioneNomeFile-3]=='t'))
{
funzioneAusiliaria(nomeDelFile); //parte in esecuzione la funzione ausiliaria
}
else
{
//Errore sul metodo di avvio del programma per la compressione/decompressione di un testo
printf("\nErrore!Il file da comprimere o da decomprimere deve avere estenzione .txt oppure .rle!\n");
}
return 0;
}