Optimale Binary Search Trees

stemmen
2

Ik heb een opdracht op optimale binary search bomen en enkele vragen kwamen terwijl doen. Ik heb veel van de links online behulpzaam (alleen vanuit een Google-zoekopdracht), maar ik vroeg me af gevonden ...

Waarom moeten moet de sleutels in eerste instantie worden opgelost?

Als ik een lagere kostprijs (voor een optimale BST) wanneer de toetsen niet worden gesorteerd te krijgen, betekent dat er moet een fout in mijn code?

Moet een optimale BST zijn complete / perfect? (Met behulp van de Wikipedia definities van volledig en perfect)

Een perfecte binaire boom is een volledige binaire boom waarin alle bladeren op dezelfde diepte of hetzelfde niveau. [1] (Dit wordt ook wel een dubbelzinnige volledige binaire boom.)

Een complete binaire boom is een binaire boom waarin elk niveau, behalve misschien de laatste, volledig gevuld, en alle knooppunten worden helemaal links mogelijk te maken. [2]

Voor de laatste vraag, zou ik neem aan dat een optimale boom complete / moet perfect zijn, maar sommige van de applets online leiden mij om iets anders te geloven. Ik kan niet waarom al reden ...

De vraag is gesteld op 01/10/2011 om 00:06
bron van user
In andere talen...                            


2 antwoorden

stemmen
1

Waarom moeten de sleutels in eerste instantie worden opgelost?

Dat doen ze niet. In feite, tenzij u gebruik maakt van een self-balancing boom, het is beter als je de sleutels toe te voegen aan de boom in willekeurige volgorde, omdat de boom zal uiteindelijk meer in evenwicht.

Als ik een lagere kostprijs (voor een optimale BST) wanneer de toetsen niet worden gesorteerd te krijgen, betekent dat er moet een fout in mijn code?

Niet tenzij je het coderen van een self-balancing boom (uw self-balancing algoritme werkt niet).

moet een optimale BST zijn complete / perfect?

Ja. Met het oog op de snelst mogelijke zoektocht naar een bepaalde boom te krijgen, moeten alle knooppunten van de boom gelijkelijk worden verdeeld; dat wil zeggen de boom moet zo kort mogelijk zijn.

antwoordde op 01/10/2011 om 00:11
bron van user

stemmen
0
void OptimalBinsearchtree_output(float R[21][20],int i, int j, int r1, char  *dir)
{
          int t;
          if (i <= j)
          {
                         t =(int)R[i][j];
                         fprintf(wp,"%s is %s child of %s\n", name[t], dir, name[r1]);
                         OptimalBinsearchtree_output(R,i, t - 1, t, "left");
                         OptimalBinsearchtree_output(R,t + 1, j, t, "right");
          }
}

void OptimalBinarySearchTree(int n, const float p[],float *minavg)
{
          int i, j, k, diagonal,l,pos;
          float R[21][20];
          float min = 0;
          float A[21][20],sum=0;
          printf("\n");
          for (i = 1; i <=n; i++) 
          {
                         A[i][i - 1] = 0;
                         R[i][i - 1] = 0;
                         A[i][i] = p[i];
                         R[i][i] = i;
                         fprintf(wp,"A[%d][%d]=%4f\tA[%d][%d]=%4f\t",i,i-1,A[i][i-1],i,i,A[i][i]);
                         fprintf(wp,"R[%d][%d]=%4f\tR[%d][%d]=%4f\n", i, i - 1, R[i][i - 1], i, i, R[i][i]);
          }

          A[n+1][n] = 0;
          R[n+1][n] = 0;
          for (diagonal = 1; diagonal <= n - 1; diagonal++)
          {
                         for (i = 1; i <= n - diagonal; i++)
                         {
                                       min = 0;
                                       sum = 0;
                                       j = i + diagonal;
                                       for (l = i; l <=j; l++)
                                       {
                                                      sum = sum + p[l];
                                       }
                                       A[i][j] = sum;
                                       for (k = i; k <= j; k++)
                                       {
                                                      sum = A[i][k - 1] + A[k + 1][j];
                                                      if (min == 0)
                                                      {
                                                                    min = sum;
                                                                    pos = k;
                                                      }
                                                      else if (sum<min)
                                                      {
                                                                    min = sum;
                                                                    pos = k;
                                                      }
                                       }
                                       A[i][j] += min;
                                       R[i][j] = pos;
                         }
          }

          *minavg = A[1][n];
          printf("\n");
          for (i = 1; i <= n; i++)
          {
                         for (j = 0; j <= n; j++)
                         {
                                       printf("%0.3f ", R[i][j]);
                         }
                         printf("\n");
          }
          for (i = 1; i <= n; i++)
          {
                         for (j = 0; j <= n; j++)
                         {
                                       printf("%0.3f ", A[i][j]);
                         }
                         printf("\n");
          }
          fprintf(wp,"\n\n");
          fprintf(wp,"%s is the root of the tree\n",name[(int)R[1][n]]);
          int r1 = (int)R[1][n];
          OptimalBinsearchtree_output(R,1, r1 - 1, r1, "left");
          OptimalBinsearchtree_output(R,r1 + 1, n, r1, "right");

}


void removeall()
{
          nodeptr node,temp;
          node = head;
          while (node->next != NULL)
          {
                         temp = node;
                         node = node->next;
          }
          if (node == node->next)
          {
                         node->next = NULL;                     
                         temp->next = NULL;
                         free(node);
                         return;
          }
          node->next = NULL;
          temp->next = NULL;
          free(node);
}

void print()
{
          nodeptr curr = NULL, temp = NULL;
          curr = head;
          gl_index = 1;
          while (curr != NULL)
          {

                         curr->index = gl_index;
                         gl_p[gl_index] = curr->val;
                         strcpy(name[gl_index], curr->str);
                         gl_index++;
                         wp=fopen("Output.txt","w+");
                         fprintf(wp,"%s\t%f\t%d\n", curr->str, curr->val, curr->index);
                         curr = curr->next;
          }
}


void generatenode()
{


          int i, j;
          nodeptr temp = NULL;
          char a[20];

          while (!feof(fp))
          {
                         nodeptr curr = NULL, prev = NULL;
                         temp = (struct node*)malloc(sizeof(struct node));
                         fscanf(fp, "%s", &temp->str);
                         fgets(a, 20, fp);
                         temp->index = gl_index;
                         b = atof(a);
                         int flag = 0;
                         temp->val = b;
                         gl_p[gl_index] = temp->val;
                         gl_index++;
                         temp->next = NULL;
                         if (head == NULL)
                         {
                                       head = temp;
                                       curr = head;
                         }
                         else
                         {
                                       curr = head;
                                       while (!(strcmp(temp->str, curr->str) < 0))
                                       {
                                                      if(curr->next==NULL)
                                                      {
                                                                    curr->next = temp;
                                                                    curr = curr->next;
                                                                    temp->next = NULL;
                                                                    flag = 0;
                                                                    break;
                                                      }
                                                      else
                                                      {
                                                                    flag = 1;
                                                                    prev = curr;
                                                                    curr = curr->next;
                                                      }
                                       }
                                       if (curr == head)
                                       {
                                                      temp->next = curr;
                                                      head = temp;
                                       }
                                       else
                                       {
                                                      if (flag == 1)
                                                      {
                                                      prev->next = temp;
                                                      temp->next = curr;
                                                      }
                                       }
                                       flag = 0;
                         }
          }
}
antwoordde op 14/12/2015 om 02:38
bron van user

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more