Compare commits
8 Commits
main
...
tobis_bran
| Author | SHA1 | Date | |
|---|---|---|---|
| 17a74ddc81 | |||
| ebb886ae9e | |||
| 1ca4567185 | |||
| bda3c2b104 | |||
| 65b20f7ea4 | |||
| 8592476b50 | |||
| d269bc321b | |||
| 7f69b71455 |
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,3 +1,5 @@
|
|||||||
makefile/
|
makefile/
|
||||||
.vscode/
|
.vscode/
|
||||||
*.exe
|
*.exe
|
||||||
|
Start_Linux/makefile
|
||||||
|
Start_Windows/makefile
|
||||||
|
|||||||
@ -6,18 +6,76 @@
|
|||||||
#define MAX_RAND_TRIES_PER_WORD 10
|
#define MAX_RAND_TRIES_PER_WORD 10
|
||||||
#define EMPTY_CHAR 0
|
#define EMPTY_CHAR 0
|
||||||
|
|
||||||
|
void emptyArray();
|
||||||
|
int placeWord();
|
||||||
|
void fillEmptySpots();
|
||||||
|
|
||||||
//TODO: Spiellogik implementieren:
|
//TODO: Spiellogik implementieren:
|
||||||
/* * Wörter aus der Wortliste zufällig horizontal oder vertikal platzieren
|
/* * Wörter aus der Wortliste zufällig horizontal oder vertikal platzieren
|
||||||
* restliche Felder mit zufälligen Buchstaben füllen */
|
* restliche Felder mit zufälligen Buchstaben füllen */
|
||||||
|
|
||||||
// Creates the word salad by placing words randomly and filling empty spaces
|
// Creates the word salad by placing words randomly and filling empty spaces
|
||||||
int createWordSalad(char salad[MAX_SEARCH_FIELD_LEN][MAX_SEARCH_FIELD_LEN], unsigned int searchFieldLen, const char words[][MAX_WORD_LEN], unsigned int wordCount)
|
int createWordSalad(char salad[MAX_SEARCH_FIELD_LEN][MAX_SEARCH_FIELD_LEN], unsigned int searchFieldLen, const char words[][MAX_WORD_LEN], unsigned int wordCount)
|
||||||
{
|
{
|
||||||
|
srand(time(NULL));
|
||||||
|
emptyArray(salad,MAX_SEARCH_FIELD_LEN * MAX_SEARCH_FIELD_LEN);
|
||||||
|
placeWord(salad,words);
|
||||||
|
fillEmptySpots(salad, MAX_SEARCH_FIELD_LEN * MAX_SEARCH_FIELD_LEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prints the word salad to console
|
// Prints the word salad to console
|
||||||
void showWordSalad(const char salad[MAX_SEARCH_FIELD_LEN][MAX_SEARCH_FIELD_LEN], unsigned int searchFieldLen)
|
void showWordSalad(const char salad[MAX_SEARCH_FIELD_LEN][MAX_SEARCH_FIELD_LEN], unsigned int searchFieldLen)
|
||||||
|
{
|
||||||
|
for(int i = 0; i <= MAX_SEARCH_FIELD_LEN; i++ )
|
||||||
|
{
|
||||||
|
for(int j = 0; j <= MAX_SEARCH_FIELD_LEN; j++)
|
||||||
|
{
|
||||||
|
printf("[%c]",salad[i][j]);
|
||||||
|
}
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void emptyArray(char array[][], int arrayLength)
|
||||||
|
{
|
||||||
|
char* element = (char*) &array;
|
||||||
|
for(int i = 0; i < arrayLength; i++ )
|
||||||
|
{
|
||||||
|
*element = EMPTY_CHAR;
|
||||||
|
element++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int placeWord(char intoArray[][], char insertedWord[][])
|
||||||
|
{
|
||||||
|
int numberWord;
|
||||||
|
int tries;
|
||||||
|
while(tries <= MAX_RAND_TRIES_PER_WORD)
|
||||||
|
{
|
||||||
|
int xCord = rand() % MAX_SEARCH_FIELD_LEN;
|
||||||
|
int yCord = rand() % MAX_SEARCH_FIELD_LEN;
|
||||||
|
int isHorizontal = rand() % 2;
|
||||||
|
unsigned int wordLength = strlen(insertedWord[numberWord][0]);
|
||||||
|
if(isHorizontal)
|
||||||
|
{
|
||||||
|
if(xCord + sizeof(insertedWord[numberWord][0]) <= MAX_SEARCH_FIELD_LEN)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void fillEmptySpots(char array[][], int arrayLength)
|
||||||
|
{
|
||||||
|
char* element = (char*) &array;
|
||||||
|
for(int i = 0; i < arrayLength; i++ )
|
||||||
|
{
|
||||||
|
if(*element == EMPTY_CHAR)
|
||||||
|
{
|
||||||
|
*element == rand() % ('Z' - 'A' + 1) + 'A';
|
||||||
|
}
|
||||||
|
element++;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -1,12 +1,36 @@
|
|||||||
#include "input.h"
|
#include "input.h"
|
||||||
#include <string.h>
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
// TODO:
|
// eine Funktion implementieren, die ein einzelnes Wort aus einer Textdatei
|
||||||
// eine Funktion implementieren, die ein einzelnes Wort aus einer Textdatei (words.txt) einliest und als C-String zurückgibt.
|
// (words.txt) einliest und als C-String zurückgibt.
|
||||||
|
|
||||||
// Read words from file and store in 'words' array
|
|
||||||
int readWords(FILE *file, char words[][MAX_WORD_LEN],unsigned int maxWordCount)
|
int readWords(FILE *file, char words[][MAX_WORD_LEN],unsigned int maxWordCount)
|
||||||
{
|
{
|
||||||
|
char puffer[MAX_WORD_LEN];
|
||||||
|
file = fopen("words.txt", "r");
|
||||||
|
if (file == NULL)
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char teiler[] = " ;,.\n";
|
||||||
|
char aktuellesWort;
|
||||||
|
int wortAnzahl = 0;
|
||||||
|
|
||||||
|
while (fgets(puffer, MAX_WORD_LEN, file) != NULL)
|
||||||
|
{
|
||||||
|
|
||||||
|
aktuellesWort = strtok(puffer, teiler);
|
||||||
|
|
||||||
|
while (aktuellesWort != NULL && wortAnzahl < maxWordCount)
|
||||||
|
{
|
||||||
|
strncpy(words[wortAnzahl], aktuellesWort,sizeof(words[wortAnzahl]) - 1);
|
||||||
|
words[wortAnzahl][sizeof(words[wortAnzahl]) - 1] = '\0';
|
||||||
|
wortAnzahl++; // Nächstes Wort
|
||||||
|
aktuellesWort = strtok(NULL, teiler); // Nächstes Token
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(file);
|
||||||
|
return wortAnzahl; // Anzahl der eingelesenen Wörter
|
||||||
}
|
}
|
||||||
@ -38,8 +38,18 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
// TODO:
|
// TODO:
|
||||||
// Check if all words were successfully placed
|
// Check if all words were successfully placed
|
||||||
|
if(placedWords == wordCount)
|
||||||
|
{
|
||||||
// Start the game if successful
|
// Start the game if successful
|
||||||
|
startGame(wordSalad,MAX_NUMBER_OF_WORDS,placedWords, wordCount,1024);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// error message if some words couldn't be placed
|
// error message if some words couldn't be placed
|
||||||
|
fprintf(stderr, "Could not place every word \n");
|
||||||
|
exitCode = EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@ -1,12 +1,54 @@
|
|||||||
#include "input.h"
|
#include "input.h"
|
||||||
#include <string.h>
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
// TODO:
|
// TODO:
|
||||||
// eine Funktion implementieren, die ein einzelnes Wort aus einer Textdatei (words.txt) einliest und als C-String zurückgibt.
|
// eine Funktion implementieren, die ein einzelnes Wort aus einer Textdatei
|
||||||
|
// (words.txt) einliest und als C-String zurückgibt.
|
||||||
|
|
||||||
// Read words from file and store in 'words' array
|
// Read words from file and store in 'words' array
|
||||||
int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount)
|
int readWords(FILE *file, char words[][MAX_WORD_LEN],
|
||||||
{
|
unsigned int maxWordCount) {
|
||||||
|
|
||||||
|
if (file == NULL) {
|
||||||
|
|
||||||
|
perror("File couldn't be opened");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// zunächst fehlerhaften String einlesen und in anderem Array
|
||||||
|
// zwischenspeichern
|
||||||
|
|
||||||
|
char fehlerhafterString[MAX_LINE_LEN];
|
||||||
|
char *teiler = " ;,.\n";
|
||||||
|
char *aktuellesWort;
|
||||||
|
int wortAnzahl = 0;
|
||||||
|
|
||||||
|
while (fgets(fehlerhafterString, sizeof(fehlerhafterString), file) !=
|
||||||
|
NULL && // während mit fgets alle Zeichen aus dem file eingelesen
|
||||||
|
// werden
|
||||||
|
wortAnzahl < maxWordCount) {
|
||||||
|
|
||||||
|
aktuellesWort =
|
||||||
|
strtok(fehlerhafterString, teiler); // Erstes Wort mit strtok aus dem
|
||||||
|
// fehlerhaften String herauslösen
|
||||||
|
|
||||||
|
while (aktuellesWort != NULL &&
|
||||||
|
wortAnzahl < maxWordCount) { // while strtok nicht am Ende ist und
|
||||||
|
// noch Wörter in words passen
|
||||||
|
|
||||||
|
strncpy(words[wortAnzahl], aktuellesWort,
|
||||||
|
sizeof(words[wortAnzahl]) -
|
||||||
|
1); // mit strcpy das aktuelle Wort in words kopieren
|
||||||
|
words[wortAnzahl][sizeof(words[wortAnzahl]) - 1] =
|
||||||
|
'\0'; // Nullterminator mit sizeof des aktuellen Worts - 1 an Ende des
|
||||||
|
// Worts setzen
|
||||||
|
|
||||||
|
wortAnzahl++; // Nächstes Wort
|
||||||
|
aktuellesWort = strtok(NULL, teiler); // Nächstes Token
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return wortAnzahl; // Anzahl der eingelesenen Wörter
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user