Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Помощ за задача по С++ с двоично дърво

Featured Replies

Зравейте! Нужна ми е помощ за следната задача: Едно дърво TR1 се съдържа в друго TR2 ако всички елементи на TR1 се съдържат в TR2.Да се състави функция която проверява дали дадено подредено двоично дърво се съдържа в друго подредено двоично дърво. 

 

#include<iostream.h>

#include<conio.h>



struct stTree

{

        char key;

        stTree *pLeft;

        stTree *pRight;

};



stTree *pRoot=NULL;

stTree *pRoot1=NULL;

stTree *pRoot2=NULL;



void addToTree(stTree *&pRoot, char Data)

{

        if(!pRoot)

        {

                pRoot=new stTree;

                pRoot->pLeft=pRoot->pRight=NULL;

                pRoot->key=Data;

        }

        else if (pRoot->key<Data)

                addToTree(pRoot->pRight,Data);

        else addToTree(pRoot->pLeft,Data);

}







void preorder(stTree *pRoot)

{ 

        if(pRoot)

        {

                cout<<pRoot->key<<" ";

                preorder(pRoot->pLeft);

                preorder(pRoot->pRight);

        }

}





void main()

{ clrscr();



char a,b;

cout<<"Vavedi st-ti za TR1. Za krai / ";

while((cin>>a) && (a!='/'))

addToTree(pRoot1,a);



cout<<"Vavedi st-ti za TR2. Za krai / ";

while((cin>>b) && (b!='/'))

addToTree(pRoot2,b);



cout<<"Darvetata sa:n";

preorder(pRoot1);

cout<<endl;

preorder(pRoot2);



getch(); }

 

Стигнал съм до тук и не мога да измисля как да съставя функцията . Благодаря предварително :) 

int find(stTree *t, int n)
{
    if (t==NULL)  return 0;
    if (t->key>n) return find(t->pLeft,n);
    if (t->key<n) return find(t->pRight,n);
    return 1;
}

int check(stTree *p, stTree *t)
{
    if (t==NULL) return 1;
    return find(p,t->key) && check(p,t->pLeft) && check(p,t->pRight);
}

 

Редактирано от ined (преглед на промените)

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.