kommentiert

This commit is contained in:
Harun Faizi 2025-11-02 22:50:25 +01:00
parent 16ab4a59ab
commit 5d13734da6

41
input.c
View File

@ -1,4 +1,4 @@
//erstellt von Harun Faizi am 01.11.2025 //erstellt von Harun Faizi am 01.11.2025; Informatik 2 Praktikum; Projekt 1
#include "input.h" #include "input.h"
#include <string.h> #include <string.h>
#include <ctype.h> #include <ctype.h>
@ -20,32 +20,46 @@
int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount) int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount)
{ //Gibt die Anzahl der eingelesen Wörter zurück (wordCount), für main wie viel gelesen wurde { //Gibt die Anzahl der eingelesen Wörter zurück (wordCount), für main wie viel gelesen wurde
//FILE *file: Zeiger auf Datei --> FILE komplexes Objekt, müssen mit Adresse arbeiten //FILE *file: Zeiger auf Datei --> FILE komplexes Objekt, müssen mit Adresse arbeiten
//Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter //word[][...]: Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter
//wie viele Wörter max in Array geschrieben werden dürfen //maxWordCount: wie viele Wörter max in Array geschrieben werden dürfen
if (file == 0) if (file == 0)
return 0; //Sicherheitsprüfung return 0; //Sicherheitsprüfung
char line[MAX_LINE_LEN]; // Puffer für eine Zeile aus Datei char line[MAX_LINE_LEN]; // Puffer für eine Zeile aus Datei --> Wörter später mit strtok() aus der Zeile extrahieren
unsigned int wordCount = 0; // zählt wie viele Wörter gefunden wurden unsigned int wordCount = 0; // zählt wie viele Wörter gefunden wurden
//Lese Datei Zeile für Zeile //Lese Datei Zeile für Zeile
while(fgets(line, sizeof(line), file) != NULL) while(fgets(line, sizeof(line), file) != NULL) //liest Zeile für Zeile
{ {
// fgets: liest komplette Zeile aus Datei
// fgets(Zielfeld, maximaleLänge, DateiZeiger);
// ==> "Lies aus Datei file bis 1024 Zeichen oder bis Zeilenumbruch \n kommt und speichere das Erg. in line"
// fgets gibt NULL zurück wenn Dateiende (EOF) erreicht ist
// fgets hängt IMMER automatisch \0 ans Ende des gelesen Textes
// Zerlege die Datei in einzelne Wörter // Zerlege die Datei in einzelne Wörter
char *token = strtok(line, ".,;\n\t"); char *token = strtok(line, ".,;\n\t");
//strtok(): "Zerlege ein String in einzelne Teile (Wörter) nach bestimmten Trennzeichen
//strtok(): ersetzt Trennzeichen mit \0, merkt sich wo aufgehört hat und macht dann weiter
//char * token: Zeiger auf ein Zeichen (Anfang eines Strings)
//"Solange es noch ein Wort gibt UND Speicherlimit noch nicht erreicht wurde, mach weiter"
while (token != NULL && wordCount < maxWordCount) while (token != NULL && wordCount < maxWordCount)
{ {
//aktuelles Wort in Array kopieren //aktuelles Wort in Array kopieren
strncpy(words[wordCount], token, MAX_WORD_LEN -1); strncpy(words[wordCount], token, MAX_WORD_LEN -1);//Kopiert Inhalt von token (aktuelles Wort) in das Array words
words[wordCount][MAX_WORD_LEN -1] = '\0'; //strcpy(Ziel, Quelle, maximaleAnzahl);
wordCount++; words[wordCount][MAX_WORD_LEN -1] = '\0';//jedes Wort im array endet mit \0
token = strtok(NULL, ",;\n");
wordCount++; //Wort gespeichert, zähle eins hoch
token = strtok(NULL, ",;\n");// sucht nächstes Wort ab Stelle, wo es aufgehört hat zuletzt
} }
// Wenn max Wortzahl erreicht ist abbrechen! // Wenn max Wortzahl erreicht ist abbrechen
if (wordCount >= maxWordCount) if (wordCount >= maxWordCount)
break; break;
} }
@ -53,6 +67,7 @@ int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount)
return wordCount; return wordCount;
} }
/* Arrays im Überblick:
line[]: eine Zeile aus der Datei
words[][]: alle Wörter einzelnd gespeichert
token: Zeiger auf das aktuelle Wort