2024-10-01 13:36:19 +00:00
|
|
|
|
#include <stdio.h>
|
2024-10-01 21:47:00 +00:00
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <ctype.h>
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-01 21:47:00 +00:00
|
|
|
|
#define MAX_DISHES 100
|
|
|
|
|
#define MAX_NAME_LEN 100
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Функция для декодирования символов
|
2024-10-01 21:47:00 +00:00
|
|
|
|
void decodovane_slovo(char *text) {
|
|
|
|
|
for (int i = 0; text[i]; i++) {
|
|
|
|
|
switch (text[i]) {
|
|
|
|
|
case '0': text[i] = 'o'; break;
|
|
|
|
|
case '1': text[i] = 'i'; break;
|
|
|
|
|
case '2': text[i] = 'z'; break;
|
|
|
|
|
case '3': text[i] = 'e'; break;
|
|
|
|
|
case '4': text[i] = 'a'; break;
|
|
|
|
|
case '5': text[i] = 's'; break;
|
|
|
|
|
case '6': text[i] = 'b'; break;
|
|
|
|
|
case '7': text[i] = 't'; break;
|
|
|
|
|
case '8': text[i] = 'b'; break;
|
|
|
|
|
case '9': text[i] = 'q'; break;
|
|
|
|
|
default: text[i] = tolower(text[i]); break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-01 13:36:19 +00:00
|
|
|
|
int main() {
|
2024-10-01 21:47:00 +00:00
|
|
|
|
char ingredient[MAX_NAME_LEN];
|
2024-10-02 17:29:21 +00:00
|
|
|
|
char dishes[MAX_DISHES][2][MAX_NAME_LEN]; // Массив для хранения блюд и цен
|
|
|
|
|
int count = 0; // Количество введенных блюд
|
2024-10-01 21:47:00 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Запрос ингредиента
|
2024-10-02 17:07:57 +00:00
|
|
|
|
printf("Zadaj hladanu surovinu:\n");
|
2024-10-02 18:01:23 +00:00
|
|
|
|
if (fgets(ingredient, MAX_NAME_LEN, stdin) == NULL) {
|
|
|
|
|
return 0; // Выход, если ввод не удался
|
|
|
|
|
}
|
|
|
|
|
ingredient[strcspn(ingredient, "\n")] = '\0'; // Удаление символа новой строки
|
|
|
|
|
printf("%s\n", ingredient); // Вывод ингредиента сразу после запроса
|
2024-10-02 16:51:23 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Запрос списка блюд
|
2024-10-02 17:07:57 +00:00
|
|
|
|
printf("Zadaj jedalny listok:\n");
|
2024-10-01 21:47:00 +00:00
|
|
|
|
while (1) {
|
|
|
|
|
char name[MAX_NAME_LEN], price[MAX_NAME_LEN];
|
2024-10-01 22:29:12 +00:00
|
|
|
|
|
2024-10-02 18:01:23 +00:00
|
|
|
|
// Чтение названия блюда
|
2024-10-01 22:03:29 +00:00
|
|
|
|
if (fgets(name, MAX_NAME_LEN, stdin) == NULL) {
|
2024-10-02 17:29:21 +00:00
|
|
|
|
return 0; // Выход, если ввод не удался
|
2024-10-01 22:03:29 +00:00
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
name[strcspn(name, "\n")] = '\0'; // Удаление символа новой строки
|
2024-10-01 22:29:12 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Если строка пустая, завершить ввод
|
2024-10-01 21:47:00 +00:00
|
|
|
|
if (strlen(name) == 0) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-02 18:01:23 +00:00
|
|
|
|
// Чтение цены
|
2024-10-01 22:03:29 +00:00
|
|
|
|
if (fgets(price, MAX_NAME_LEN, stdin) == NULL) {
|
2024-10-02 17:29:21 +00:00
|
|
|
|
return 0; // Выход, если ввод не удался
|
2024-10-01 22:03:29 +00:00
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
price[strcspn(price, "\n")] = '\0'; // Удаление символа новой строки
|
2024-10-01 21:47:00 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Сохранение названия блюда и цены
|
2024-10-01 22:00:31 +00:00
|
|
|
|
strncpy(dishes[count][0], name, MAX_NAME_LEN - 1);
|
2024-10-02 17:29:21 +00:00
|
|
|
|
dishes[count][0][MAX_NAME_LEN - 1] = '\0'; // Завершение строки
|
2024-10-01 22:00:31 +00:00
|
|
|
|
|
|
|
|
|
strncpy(dishes[count][1], price, MAX_NAME_LEN - 1);
|
2024-10-02 17:29:21 +00:00
|
|
|
|
dishes[count][1][MAX_NAME_LEN - 1] = '\0'; // Завершение строки
|
2024-10-01 22:00:31 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
count++; // Увеличение счётчика блюд
|
2024-10-01 21:47:00 +00:00
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Декодирование введенного ингредиента
|
|
|
|
|
decodovane_slovo(ingredient);
|
2024-10-02 16:46:39 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Поиск и вывод блюд, содержащих искомый ингредиент
|
2024-10-02 18:01:23 +00:00
|
|
|
|
int found = 0; // Флаг для отслеживания, если хотя бы одно блюдо будет найдено
|
2024-10-01 21:47:00 +00:00
|
|
|
|
for (int i = 0; i < count; i++) {
|
|
|
|
|
char decoded_name[MAX_NAME_LEN];
|
2024-10-01 21:57:29 +00:00
|
|
|
|
strncpy(decoded_name, dishes[i][0], MAX_NAME_LEN - 1);
|
2024-10-02 16:46:39 +00:00
|
|
|
|
decoded_name[MAX_NAME_LEN - 1] = '\0';
|
2024-10-01 21:47:00 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
decodovane_slovo(decoded_name); // Декодируем название блюда
|
2024-10-01 21:47:00 +00:00
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
if (strstr(decoded_name, ingredient) != NULL) { // Проверка на совпадение с ингредиентом
|
|
|
|
|
printf("%s %s\n", dishes[i][0], dishes[i][1]); // Вывод оригинального названия и цены
|
2024-10-02 18:01:23 +00:00
|
|
|
|
found = 1;
|
2024-10-01 21:47:00 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-02 17:25:52 +00:00
|
|
|
|
|
2024-10-02 18:01:23 +00:00
|
|
|
|
if (!found) {
|
|
|
|
|
printf("\n"); // Если блюда не найдены, добавить пустую строку перед счетчиком
|
|
|
|
|
}
|
|
|
|
|
|
2024-10-02 17:29:21 +00:00
|
|
|
|
// Вывод количества введенных блюд
|
2024-10-02 17:25:52 +00:00
|
|
|
|
printf("Nacitanych %d poloziek.\n", count);
|
2024-10-01 13:36:19 +00:00
|
|
|
|
return 0;
|
2024-10-01 22:00:31 +00:00
|
|
|
|
}
|