Update cv1/program.c

This commit is contained in:
Viktor Daniv 2024-10-04 12:28:10 +00:00
parent aafa730da7
commit c736f318b0

View File

@ -2,78 +2,93 @@
#include <string.h>
#include <ctype.h>
// Funkcia na porovnanie znakov podľa pravidiel Hack3r scr1pt
int isHack3rEquivalent(char c1, char c2) {
char table[256] = {0};
table['0'] = 'o'; table['o'] = '0';
table['1'] = 'i'; table['i'] = '1';
table['2'] = 'z'; table['z'] = '2';
table['3'] = 'e'; table['e'] = '3';
table['4'] = 'a'; table['a'] = '4';
table['5'] = 's'; table['s'] = '5';
table['6'] = 'b'; table['b'] = '6';
table['7'] = 't'; table['t'] = '7';
table['8'] = 'b'; table['b'] = '8';
table['9'] = 'q'; table['q'] = '9';
#define MAX_DISHES 100
#define MAX_NAME_LENGTH 100
c1 = tolower(c1);
c2 = tolower(c2);
if (c1 == c2) return 1;
return table[(unsigned char)c1] == c2;
}
// Funkcia na zistenie, či sa reťazec hľadanej suroviny nachádza v názve jedla
int isHack3rMatch(const char *name, const char *search) {
int name_len = strlen(name);
int search_len = strlen(search);
for (int i = 0; i <= name_len - search_len; i++) {
int match = 1;
for (int j = 0; j < search_len; j++) {
if (!isHack3rEquivalent(name[i + j], search[j])) {
match = 0;
// Funkcia na prekonvertovanie textu do formátu Hacker script
void to_hacker_script(char *input, char *output) {
while (*input) {
switch (*input) {
case 'o':
case 'O':
*output++ = '0';
break;
case 'i':
case 'I':
*output++ = '1';
break;
case 'z':
case 'Z':
*output++ = '2';
break;
case 'e':
case 'E':
*output++ = '3';
break;
case 'a':
case 'A':
*output++ = '4';
break;
case 's':
case 'S':
*output++ = '5';
break;
case 'b':
case 'B':
*output++ = '6';
break;
case 't':
case 'T':
*output++ = '7';
break;
case 'q':
case 'Q':
*output++ = '9';
break;
case '8':
*output++ = '8';
break;
default:
*output++ = tolower(*input);
break;
}
input++;
}
if (match) return 1;
}
return 0;
*output = '\0';
}
int main() {
char line[200];
char name[100];
char price[20];
char search_term[MAX_NAME_LENGTH];
char dish_name[MAX_NAME_LENGTH];
char dish_price[MAX_NAME_LENGTH];
char hacker_search[MAX_NAME_LENGTH];
int count = 0;
printf("Zadaj hladanu surovinu:\n");
fgets(name, sizeof(name), stdin);
name[strcspn(name, "\n")] = 0; // Odstráni znak nového riadku
printf("Zadaj hladanu surovinu: ");
scanf("%s", search_term);
// Prekonvertovanie hladanej suroviny do Hacker script
to_hacker_script(search_term, hacker_search);
printf("Zadaj jedalny listok:\n");
while (1) {
// Načítanie názvu položky
if (fgets(line, sizeof(line), stdin) == NULL || strcmp(line, "\n") == 0) {
break; // Ak nie sú ďalšie riadky alebo je prázdny riadok, ukončujeme
if (scanf("%s", dish_name) == EOF) {
break;
}
line[strcspn(line, "\n")] = 0; // Odstráni znak nového riadku
scanf("%s", dish_price);
// Načítanie nasledujúceho riadku, ktorý obsahuje cenu
if (fgets(price, sizeof(price), stdin) == NULL || strcmp(price, "\n") == 0) {
break; // Ak nie sú ďalšie riadky alebo je prázdny riadok, ukončujeme
}
price[strcspn(price, "\n")] = 0; // Odstráni znak nového riadku
// Vytvorenie prekonvertovanej názvu jedla
char hacker_dish_name[MAX_NAME_LENGTH];
to_hacker_script(dish_name, hacker_dish_name);
// Ak je zhodná, vypíšeme názov a cenu
if (isHack3rMatch(line, name)) {
printf("%s\n%s\n", line, price);
// Kontrola, či názov jedla obsahuje vyhľadávanú surovinu
if (strstr(hacker_dish_name, hacker_search) != NULL) {
printf("%s\n%s\n", dish_name, dish_price);
count++;
}
}
printf("Nacitanych %d poloziek.\n", count);
return 0;
}