#include #include #include #define SIZE 256 typedef struct Tree { char text[SIZE]; int isAnswer; struct Tree *yes; struct Tree *no; } Tree; // читання дерева Tree* readTree() { char line[SIZE]; if (fgets(line, SIZE, stdin) == NULL) return NULL; line[strcspn(line, "\r\n")] = 0; if (line[0] == '\0') return NULL; Tree *node = malloc(sizeof(Tree)); node->yes = NULL; node->no = NULL; if (line[0] == '*') { node->isAnswer = 1; int i = 1; while (line[i] == ' ') i++; strcpy(node->text, line + i); } else { node->isAnswer = 0; strcpy(node->text, line); node->yes = readTree(); node->no = readTree(); } return node; } // перевірка пустого рядка int EmptyLine() { char line[SIZE]; if (fgets(line, SIZE, stdin) == NULL) return 0; return (strcmp(line, "\n") == 0); } // кількість листків int Leaves(Tree *node) { if (!node) return 0; if (node->isAnswer) return 1; return Leaves(node->yes) + Leaves(node->no); } // free void freeTree(Tree *node) { if (!node) return; freeTree(node->yes); freeTree(node->no); free(node); } // запуск void start(Tree *node) { char input[SIZE]; while (node && !node->isAnswer) { printf("%s\n", node->text); if (fgets(input, SIZE, stdin) == NULL) { printf("Koniec vstupu\n"); return; } if (input[0] == 'a') { node = node->yes; } else if (input[0] == 'n') { node = node->no; } else { printf("Nerozumiem\n"); return; } } if (node && node->isAnswer) { printf("* %s\n", node->text); printf("Koniec\n"); } } int main() { printf("Expert z bufetu to vie.\n"); Tree *root = readTree(); if (!root) { printf("Chyba nacitania\n"); return 0; } if (!EmptyLine()) { printf("Chyba nacitania\n"); freeTree(root); return 0; } printf("Pozna %d druhov ovocia a zeleniny.\n", Leaves(root)); printf("Odpovedajte 'a' pre prvu moznost alebo 'n' pre druhu moznost.\n"); start(root); freeTree(root); return 0; }