Update cv1/program.c

This commit is contained in:
Yurii Chechur 2024-10-02 17:38:55 +00:00
parent 87cb8dcee3
commit bd79afd389

View File

@ -1,130 +1,101 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <stdlib.h> #include <ctype.h>
#define LINESIZE 100 #define LINESIZE 100
#define MAX_PIZZA 100
// Структура для зберігання інформації про піцу struct MenuItem {
struct pizza { char dish[LINESIZE];
float prize; // Ціна піци float price;
char name[LINESIZE]; // Назва піци
}; };
// Функція для перетворення символу у "Hacker Script" // Функція для нормалізації рядка за правилами "Hacker Script"
char hacker_script(char c) { void normalize(char* str) {
// Приводимо до нижнього регістру for (int i = 0; str[i]; i++) {
if (c >= 'A' && c <= 'Z') { // Замінюємо великі літери на маленькі
c += 32; // Перетворюємо у нижній регістр str[i] = tolower(str[i]);
}
// Заміна символів відповідно до "Hacker Script"
// Замінюємо літери на цифри switch (str[i]) {
switch (c) { case 'o': str[i] = '0'; break;
case 'o': return '0'; case 'i': str[i] = '1'; break;
case 'i': return '1'; case 'z': str[i] = '2'; break;
case 'z': return '2'; case 'e': str[i] = '3'; break;
case 'e': return '3'; case 'a': str[i] = '4'; break;
case 'a': return '4'; case 's': str[i] = '5'; break;
case 's': return '5'; case 'b': str[i] = '6'; break; // Залишаємо 'b' на 6
case 'b': return '6'; case 't': str[i] = '7'; break;
case 't': return '7'; case 'g': str[i] = '9'; break; // Додаємо 'g' на 9
case 'g': return '8'; case 'q': str[i] = '9'; break; // Додаємо 'q' на 9
case 'q': return '9'; default: break; // нічого не робимо для інших символів
default: return c; // Повертаємо без змін
}
}
// Функція для нормалізації рядка
void normalize_string(const char* input, char* output) {
int i = 0;
while (input[i] != '\0' && i < LINESIZE - 1) {
output[i] = hacker_script(input[i]);
i++;
}
output[i] = '\0'; // Додаємо термінатор рядка
}
// Функція для пошуку підрядка з урахуванням "Hacker Script"
int search_string(const char* heap, const char* needle) {
int len_heap = strlen(heap);
int len_needle = strlen(needle);
for (int i = 0; i <= len_heap - len_needle; i++) {
int j;
for (j = 0; j < len_needle; j++) {
if (hacker_script(heap[i + j]) != hacker_script(needle[j])) {
break; // Не співпадає
}
}
if (j == len_needle) {
return i; // Знайдено
} }
} }
return -1; // Не знайдено
} }
// Функція для читання однієї піци // Функція для зчитування страви
int read_pizza(struct pizza* item) { int read_menu_item(struct MenuItem* item) {
char line[LINESIZE]; // Для назви піци // Зчитуємо назву страви
char line2[LINESIZE]; // Для ціни if (fgets(item->dish, LINESIZE, stdin) == NULL) {
return 0; // Якщо зчитування не вдалося
// Читаємо назву піци
if (fgets(line, sizeof(line), stdin) == NULL) {
return 0; // Помилка при читанні
} }
// Перевіряємо, чи введено "end"
if (strcmp(item->dish, "end\n") == 0) {
return 0; // Якщо введено "end", виходимо
}
item->dish[strcspn(item->dish, "\n")] = 0; // видаляємо символ нового рядка
// Видаляємо символ нового рядка з назви // Зчитуємо ціну
line[strcspn(line, "\n")] = 0; if (scanf("%f", &item->price) != 1) {
getchar(); // очищуємо буфер вводу
// Читаємо ціну return 0; // Якщо зчитування не вдалося
if (fgets(line2, sizeof(line2), stdin) == NULL) {
return 0; // Помилка при читанні
} }
getchar(); // очищуємо буфер вводу
// Перетворюємо рядок ціни у число з плаваючою комою return 1; // Успішне зчитування
float value = strtof(line2, NULL);
if (value == 0.0F && line2[0] != '0') {
return 0; // Перетворення не вдалося
}
// Копіюємо дані у структуру
item->prize = value;
strcpy(item->name, line);
return 1; // Успішно
} }
int main() { int main(void) {
struct pizza jedalny_listok[MAX_PIZZA]; // Масив для зберігання позицій меню struct MenuItem menu[LINESIZE];
int counter = 0; int item_count = 0;
printf("Zadaj hladanu surovinu:\n"); char search_string[LINESIZE];
char search_string_input[LINESIZE]; // Для пошукового запиту
fgets(search_string_input, sizeof(search_string_input), stdin);
// Видаляємо символ нового рядка з пошукового рядка printf("Zadaj hladanu surovinu: ");
search_string_input[strcspn(search_string_input, "\n")] = 0; fgets(search_string, LINESIZE, stdin);
search_string[strcspn(search_string, "\n")] = 0; // видаляємо символ нового рядка
// Нормалізуємо рядок для пошуку
normalize(search_string);
printf("Zadaj jedalny listok:\n"); printf("Zadaj jedalny listok:\n");
// Читаємо піци до тих пір, поки не буде помилка
while (read_pizza(&jedalny_listok[counter]) && counter < MAX_PIZZA) { while (item_count < LINESIZE) { // Додаємо перевірку на розмір
counter++; struct MenuItem item;
if (!read_menu_item(&item)) {
break; // Виходимо з циклу при некоректному зчитуванні або "end"
}
// Нормалізуємо назву страви
normalize(item.dish);
menu[item_count++] = item; // Додаємо страву в меню
} }
// Обробка пошуку // Пошук і вивід знайдених страв
printf("Vyhovujuce jedla:\n"); int found = 0;
for (int i = 0; i < item_count; i++) {
char normalized_search[LINESIZE]; // Для нормалізованого пошукового рядка if (strstr(menu[i].dish, search_string) != NULL) {
normalize_string(search_string_input, normalized_search); // Нормалізуємо пошуковий рядок printf("%s\n%.2f\n", menu[i].dish, menu[i].price);
found = 1;
for (int i = 0; i < counter; i++) {
char normalized_name[LINESIZE]; // Для нормалізованої назви піци
normalize_string(jedalny_listok[i].name, normalized_name); // Нормалізуємо назву піци
if (search_string(normalized_name, normalized_search) != -1) {
printf("%s má cenu %.2f\n", jedalny_listok[i].name, jedalny_listok[i].prize);
} }
} }
printf("Nacitanych %d poloziek.\n", counter); if (!found) {
printf("Zadana surovina nebola najdena.\n");
}
printf("Nacitanych %d poloziek.\n", item_count);
return 0; return 0;
} }