Update cv7/program.c
This commit is contained in:
		
							parent
							
								
									77b8d63418
								
							
						
					
					
						commit
						e6391fbe83
					
				@ -71,4 +71,62 @@ void print_tree(Tree* tree, int offset) {
 | 
				
			|||||||
    printf("%s\n", tree->value);
 | 
					    printf("%s\n", tree->value);
 | 
				
			||||||
    print_tree(tree->left, offset + 3);
 | 
					    print_tree(tree->left, offset + 3);
 | 
				
			||||||
    print_tree(tree->right, offset + 3);
 | 
					    print_tree(tree->right, offset + 3);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ask_question(Tree* tree) {
 | 
				
			||||||
 | 
					    if (!tree) return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    printf("%s (a/n) ?\n", tree->value);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Ak ide o odpoveď, ukončujeme
 | 
				
			||||||
 | 
					    if (tree->left == NULL && tree->right == NULL) {
 | 
				
			||||||
 | 
					        printf("Koniec\n");
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    char answer;
 | 
				
			||||||
 | 
					    scanf(" %c", &answer);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Kontrola platnej odpovede
 | 
				
			||||||
 | 
					    if (answer == 'a') {
 | 
				
			||||||
 | 
					        ask_question(tree->left); // Pre odpoveď "a"
 | 
				
			||||||
 | 
					    } else if (answer == 'n') {
 | 
				
			||||||
 | 
					        ask_question(tree->right); // Pre odpoveď "n"
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        printf("Neplatná odpoveď, koniec.\n");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int main() {
 | 
				
			||||||
 | 
					    // Načítanie stromu zo vstupu
 | 
				
			||||||
 | 
					    Tree* root = read_tree();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Ak strom nie je prázdny
 | 
				
			||||||
 | 
					    if (root == NULL) {
 | 
				
			||||||
 | 
					        printf("Chyba pri načítaní pravidiel.\n");
 | 
				
			||||||
 | 
					        return 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Preverenie a počítanie listových uzlov
 | 
				
			||||||
 | 
					    int num_items = 0;
 | 
				
			||||||
 | 
					    Tree* temp = root;
 | 
				
			||||||
 | 
					    // Rekurzívne prechádzanie a počítanie
 | 
				
			||||||
 | 
					    void count_items(Tree* tree) {
 | 
				
			||||||
 | 
					        if (tree == NULL) return;
 | 
				
			||||||
 | 
					        if (tree->left == NULL && tree->right == NULL) {
 | 
				
			||||||
 | 
					            num_items++;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        count_items(tree->left);
 | 
				
			||||||
 | 
					        count_items(tree->right);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    count_items(root);
 | 
				
			||||||
 | 
					    printf("Pozna %d druhov ovocia a zeleniny.\n", num_items);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Spustenie otázok
 | 
				
			||||||
 | 
					    ask_question(root);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Uvoľnenie pamäte
 | 
				
			||||||
 | 
					    destroy_tree(root);
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user