From 9976b61398a363cb86472afa66b711931b9510ef Mon Sep 17 00:00:00 2001 From: Maryna Kravtsova Date: Sun, 29 Nov 2020 22:06:52 +0100 Subject: [PATCH] aktivita --- a3/program.c | 87 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 87 insertions(+) create mode 100644 a3/program.c diff --git a/a3/program.c b/a3/program.c new file mode 100644 index 0000000..84bda4d --- /dev/null +++ b/a3/program.c @@ -0,0 +1,87 @@ +#include +#include +#include +#include +#include +#include + +void check_heap(int size, int* array){ + int i; + for(i = 0; i < size; i++){ + int c = (2 * i) + 1; + if(c >= size) break; + + if(!(array[c] >= array[i])){ + printf("Nie je to kopa.\n"); + return; + } + + c = (2 * i) + 2; + if(c >= size) break; + if(!(array[c] >= array[i])){ + printf("Nie je to kopa.\n"); + return; + } + + } + printf("Je to kopa:\n"); + +} + + +void space(int l){ + int i = 0; + for(i = 0; i < l; i++){ + printf(" "); + } + +} + +void print(int *arr, int i, int size, int c, int level){ + if(i >= size){ + return; + } + space(level); + printf("%d\n", arr[i]); + print(arr,i*2+1, size, c, level+1); + + print(arr, i*2+2, size, c, level+1); +} + + +int main() { + char* cisla = calloc(100, sizeof(char)); + + fgets(cisla, 100, stdin); + int size = cisla[strlen(cisla)-1]; + int* num = calloc(size, sizeof(int)); + char *end; + int i = 0; + while(i != size){ + if(i == 0){ + long int c = strtol(cisla, &end, 10); + num[i] = c; + + } + else{ + long int next = strtol(end, &end, 10); + num[i] = next; + } + i++; + + } + i = 0; + int count = 0; + while(num[i] != 0){ + count++; + i++; + } + i = 0; + int index = 0; + int l = 0; + int k = 36; + check_heap(count, num); + int j = 0; + print(num, index, count,num[0],l); + return 0; +}