usaa24/cv1/program.c

131 lines
4.4 KiB
C
Raw Normal View History

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 16:42:43 +00:00
#include <stdlib.h>
2024-09-30 16:41:25 +00:00
2024-10-02 16:42:43 +00:00
#define LINESIZE 100
2024-10-02 17:08:37 +00:00
#define MAX_PIZZA 100
2024-09-30 11:43:46 +00:00
2024-10-02 17:08:37 +00:00
// Структура для зберігання інформації про піцу
2024-10-02 16:42:43 +00:00
struct pizza {
2024-10-02 17:08:37 +00:00
float prize; // Ціна піци
char name[LINESIZE]; // Назва піци
2024-09-30 11:43:46 +00:00
};
2024-10-02 17:08:37 +00:00
// Функція для перетворення символу у "Hacker Script"
2024-10-02 16:42:43 +00:00
char hacker_script(char c) {
2024-10-02 17:08:37 +00:00
// Приводимо до нижнього регістру
if (c >= 'A' && c <= 'Z') {
c += 32; // Перетворюємо у нижній регістр
}
// Замінюємо літери на цифри
2024-10-02 16:42:43 +00:00
switch (c) {
2024-10-02 16:24:50 +00:00
case 'o': return '0';
case 'i': return '1';
case 'z': return '2';
case 'e': return '3';
case 'a': return '4';
case 's': return '5';
2024-10-02 17:08:37 +00:00
case 'b': return '6';
2024-10-02 16:24:50 +00:00
case 't': return '7';
2024-10-02 17:08:37 +00:00
case 'g': return '8';
2024-10-02 16:24:50 +00:00
case 'q': return '9';
2024-10-02 17:08:37 +00:00
default: return c; // Повертаємо без змін
2024-10-02 16:24:50 +00:00
}
}
2024-09-30 11:43:46 +00:00
2024-10-02 17:08:37 +00:00
// Функція для нормалізації рядка
void normalize_string(const char* input, char* output) {
int i = 0;
while (input[i] != '\0' && i < LINESIZE - 1) {
2024-10-02 16:42:43 +00:00
output[i] = hacker_script(input[i]);
2024-10-02 17:08:37 +00:00
i++;
2024-10-02 08:31:44 +00:00
}
2024-10-02 17:08:37 +00:00
output[i] = '\0'; // Додаємо термінатор рядка
2024-10-02 16:24:50 +00:00
}
2024-10-02 08:31:44 +00:00
2024-10-02 17:08:37 +00:00
// Функція для пошуку підрядка з урахуванням "Hacker Script"
int search_string(const char* heap, const char* needle) {
int len_heap = strlen(heap);
int len_needle = strlen(needle);
2024-10-02 07:58:10 +00:00
2024-10-02 17:08:37 +00:00
for (int i = 0; i <= len_heap - len_needle; i++) {
2024-10-02 16:42:43 +00:00
int j;
2024-10-02 17:08:37 +00:00
for (j = 0; j < len_needle; j++) {
if (hacker_script(heap[i + j]) != hacker_script(needle[j])) {
break; // Не співпадає
}
}
if (j == len_needle) {
return i; // Знайдено
}
2024-09-30 11:43:46 +00:00
}
2024-10-02 16:42:43 +00:00
return -1; // Не знайдено
2024-09-30 11:43:46 +00:00
}
2024-10-02 17:08:37 +00:00
// Функція для читання однієї піци
int read_pizza(struct pizza* item) {
char line[LINESIZE]; // Для назви піци
char line2[LINESIZE]; // Для ціни
// Читаємо назву піци
if (fgets(line, sizeof(line), stdin) == NULL) {
return 0; // Помилка при читанні
}
// Видаляємо символ нового рядка з назви
line[strcspn(line, "\n")] = 0;
// Читаємо ціну
if (fgets(line2, sizeof(line2), stdin) == NULL) {
return 0; // Помилка при читанні
}
// Перетворюємо рядок ціни у число з плаваючою комою
float value = strtof(line2, NULL);
if (value == 0.0F && line2[0] != '0') {
return 0; // Перетворення не вдалося
}
// Копіюємо дані у структуру
item->prize = value;
strcpy(item->name, line);
return 1; // Успішно
}
2024-10-02 16:24:50 +00:00
int main() {
2024-10-02 17:08:37 +00:00
struct pizza jedalny_listok[MAX_PIZZA]; // Масив для зберігання позицій меню
int counter = 0;
2024-09-30 16:41:25 +00:00
2024-10-02 16:42:43 +00:00
printf("Zadaj hladanu surovinu:\n");
2024-10-02 17:08:37 +00:00
char search_string_input[LINESIZE]; // Для пошукового запиту
fgets(search_string_input, sizeof(search_string_input), stdin);
2024-10-02 16:24:50 +00:00
2024-10-02 17:08:37 +00:00
// Видаляємо символ нового рядка з пошукового рядка
search_string_input[strcspn(search_string_input, "\n")] = 0;
2024-10-02 16:24:50 +00:00
2024-10-02 16:42:43 +00:00
printf("Zadaj jedalny listok:\n");
2024-10-02 17:08:37 +00:00
// Читаємо піци до тих пір, поки не буде помилка
while (read_pizza(&jedalny_listok[counter]) && counter < MAX_PIZZA) {
counter++;
2024-10-02 16:42:43 +00:00
}
2024-10-02 16:24:50 +00:00
2024-10-02 17:08:37 +00:00
// Обробка пошуку
printf("Vyhovujuce jedla:\n");
char normalized_search[LINESIZE]; // Для нормалізованого пошукового рядка
normalize_string(search_string_input, normalized_search); // Нормалізуємо пошуковий рядок
for (int i = 0; i < counter; i++) {
char normalized_name[LINESIZE]; // Для нормалізованої назви піци
normalize_string(jedalny_listok[i].name, normalized_name); // Нормалізуємо назву піци
2024-10-02 16:42:43 +00:00
if (search_string(normalized_name, normalized_search) != -1) {
2024-10-02 17:08:37 +00:00
printf("%s má cenu %.2f\n", jedalny_listok[i].name, jedalny_listok[i].prize);
2024-10-02 16:42:43 +00:00
}
}
2024-10-02 16:24:50 +00:00
2024-10-02 17:08:37 +00:00
printf("Nacitanych %d poloziek.\n", counter);
2024-10-02 16:24:50 +00:00
return 0;
2024-10-02 08:31:44 +00:00
}