Помогите с С++ (Деревья) Написать код ** С++

+942 голосов
4.8m просмотров

Помогите с С++ (Деревья) Написать код на С++


Другие предметы (40 баллов) | 4.8m просмотров
Дан 1 ответ
+182 голосов

Ответ:

Объяснение:

#include

using namespace std;

//добавлен фиктивный 0-й элемент, чтобы нумерация была как

//в задании (в с++ нумеровать массивы можно только с 0)

int arr[16] = {0, 10, 22, 16, 11, 45, 25, 25, 4, 10, 7, 8, 25, 10, 1, 9};

// чтобы найти сумму в поддереве вершины i, нужно вызвать

// recurrent_sum(i);

int recurrent_sum(int current){

   //условие выхода из рекурсии

   if(current > 15){

       return 0;

   }

   return arr[current] + recurrent_sum(2 * current) + recurrent_sum(2 * current + 1);

}

int even_counter(int current){

   if(current > 15){

       return 0;

   }

   return (arr[current] % 2 == 0 ? 1 : 0) + even_counter(2 * current) + even_counter(2 * current + 1);

}

int main(){

   //проверяем, что всё работает.

   cout << recurrent_sum(1) << endl; //228</p>

   cout << even_counter(1) << endl; //7</p>

   return 0;

}

(1.4k баллов)