2024-09-30 11:43:46 +00:00
|
|
|
|
#include <stdio.h>
|
2024-10-02 16:24:50 +00:00
|
|
|
|
#include <string.h>
|
2024-10-02 17:38:55 +00:00
|
|
|
|
#include <ctype.h>
|
2024-09-30 16:41:25 +00:00
|
|
|
|
|
2024-10-02 16:42:43 +00:00
|
|
|
|
#define LINESIZE 100
|
2024-09-30 11:43:46 +00:00
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
struct MenuItem {
|
|
|
|
|
char dish[LINESIZE];
|
|
|
|
|
float price;
|
2024-09-30 11:43:46 +00:00
|
|
|
|
};
|
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Функція для нормалізації рядка за правилами "Hacker Script"
|
2024-10-02 17:38:55 +00:00
|
|
|
|
void normalize(char* str) {
|
|
|
|
|
for (int i = 0; str[i]; i++) {
|
|
|
|
|
str[i] = tolower(str[i]);
|
|
|
|
|
switch (str[i]) {
|
|
|
|
|
case 'o': str[i] = '0'; break;
|
|
|
|
|
case 'i': str[i] = '1'; break;
|
|
|
|
|
case 'z': str[i] = '2'; break;
|
|
|
|
|
case 'e': str[i] = '3'; break;
|
|
|
|
|
case 'a': str[i] = '4'; break;
|
|
|
|
|
case 's': str[i] = '5'; break;
|
2024-10-02 19:13:58 +00:00
|
|
|
|
case 'd': str[i] = '6'; break; // 'b' mapped to '6'
|
2024-10-02 17:38:55 +00:00
|
|
|
|
case 't': str[i] = '7'; break;
|
2024-10-02 19:13:58 +00:00
|
|
|
|
case 'b': str[i] = '8'; break;
|
2024-10-02 18:26:22 +00:00
|
|
|
|
case 'q': str[i] = '9'; break;
|
2024-10-02 19:13:58 +00:00
|
|
|
|
default: break; // 'r', 'y', 'n', 'd' залишаються незмінними
|
2024-10-02 17:08:37 +00:00
|
|
|
|
}
|
2024-09-30 11:43:46 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Функція для зчитування позиції меню
|
2024-10-02 17:38:55 +00:00
|
|
|
|
int read_menu_item(struct MenuItem* item) {
|
|
|
|
|
if (fgets(item->dish, LINESIZE, stdin) == NULL) {
|
2024-10-02 19:13:58 +00:00
|
|
|
|
return 0; // Якщо зчитування не вдалося
|
2024-10-02 17:08:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
if (strcmp(item->dish, "end\n") == 0) {
|
2024-10-02 19:13:58 +00:00
|
|
|
|
return 0; // Команда виходу "end"
|
2024-10-02 17:08:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
item->dish[strcspn(item->dish, "\n")] = 0; // Видалити символ нового рядка
|
2024-10-02 18:26:22 +00:00
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
if (scanf("%f", &item->price) != 1) {
|
2024-10-02 19:13:58 +00:00
|
|
|
|
getchar(); // Очищення буфера введення
|
|
|
|
|
return 0; // Якщо зчитування не вдалося
|
2024-10-02 17:08:37 +00:00
|
|
|
|
}
|
2024-10-02 19:13:58 +00:00
|
|
|
|
getchar(); // Очищення буфера введення
|
2024-10-02 17:08:37 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
return 1; // Успішне зчитування
|
2024-10-02 17:08:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
int main(void) {
|
|
|
|
|
struct MenuItem menu[LINESIZE];
|
|
|
|
|
int item_count = 0;
|
2024-09-30 16:41:25 +00:00
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
char search_string[LINESIZE];
|
2024-10-02 16:24:50 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Запит на інгредієнт для пошуку
|
2024-10-02 17:38:55 +00:00
|
|
|
|
printf("Zadaj hladanu surovinu: ");
|
|
|
|
|
fgets(search_string, LINESIZE, stdin);
|
2024-10-02 19:13:58 +00:00
|
|
|
|
search_string[strcspn(search_string, "\n")] = 0; // Видалити символ нового рядка
|
2024-10-02 16:24:50 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Нормалізація рядка пошуку
|
|
|
|
|
normalize(search_string);
|
2024-10-02 16:24:50 +00:00
|
|
|
|
|
2024-10-02 17:38:55 +00:00
|
|
|
|
printf("Zadaj jedalny listok:\n");
|
2024-10-02 17:08:37 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Цикл для зчитування позицій меню
|
2024-10-02 18:26:22 +00:00
|
|
|
|
while (item_count < LINESIZE) {
|
2024-10-02 17:38:55 +00:00
|
|
|
|
struct MenuItem item;
|
|
|
|
|
if (!read_menu_item(&item)) {
|
2024-10-02 19:13:58 +00:00
|
|
|
|
break; // Вихід з циклу на помилці зчитування або "end"
|
2024-10-02 17:38:55 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Нормалізація назви страви
|
2024-10-02 18:46:51 +00:00
|
|
|
|
normalize(item.dish);
|
2024-10-02 19:13:58 +00:00
|
|
|
|
menu[item_count++] = item; // Додати позицію до меню
|
2024-10-02 17:38:55 +00:00
|
|
|
|
}
|
2024-10-02 17:08:37 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Пошук та вивід знайдених страв
|
2024-10-02 17:38:55 +00:00
|
|
|
|
int found = 0;
|
|
|
|
|
for (int i = 0; i < item_count; i++) {
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Виконати прямий пошук нормалізованої страви проти нормалізованого рядка пошуку
|
|
|
|
|
if (strstr(menu[i].dish, search_string) != NULL) {
|
2024-10-02 17:38:55 +00:00
|
|
|
|
printf("%s\n%.2f\n", menu[i].dish, menu[i].price);
|
2024-10-02 19:13:58 +00:00
|
|
|
|
found = 1; // Хоча б одна страва знайдена
|
2024-10-02 16:42:43 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-02 16:24:50 +00:00
|
|
|
|
|
2024-10-02 19:13:58 +00:00
|
|
|
|
// Якщо пошук був неуспішним, нічого не виводимо
|
|
|
|
|
// Підрахунок зчитаних позицій
|
2024-10-02 17:38:55 +00:00
|
|
|
|
printf("Nacitanych %d poloziek.\n", item_count);
|
|
|
|
|
|
2024-10-02 16:24:50 +00:00
|
|
|
|
return 0;
|
2024-10-02 08:31:44 +00:00
|
|
|
|
}
|