#define _CRT_SECURE_NO_DEPRECATE
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <conio.h>
using namespace std;
const int n = 4000;
const int B = 256;
struct record2 {
char a[30];
union {
unsigned short int b;
unsigned char Digit[2];
};
char c[10];
char d[22];
};
struct Vertex {
record2 *Data;
int Bal;
Vertex *left;
Vertex *right;
};
bool Rost;
bool Decrease;
struct list {
list *next;
record2 *Data;
};
typedef struct queue {
list *head;
list *tail;
};
void PrintList(list *p) {
int i = 1;
char c = 'y';
while (c == 'y') {
for (int j = 0; j < 20; j++) {
printf("%d %s %d %s %s \n", i
, p
->Data
->a
, p
->Data
->b
, p
->Data
->c
, p
->Data
->d
); p = p->next;
i++;
}
c = '0';
while ((c != 'y') && (c != 'n')) {
c = '0';
printf("\n\nPrint next 20 records? y/n\n"); if ((c
!= 'y') && (c
!= 'n')) printf("Invalid input\n"); }
}
if (c == 'n') {
do {
while ((_kbhit() != 1) && (p != NULL)) {
printf("%d %s %d %s %s \n", i
, p
->Data
->a
, p
->Data
->b
, p
->Data
->c
, p
->Data
->d
); p = p->next;
i++;
}
} while (p != NULL);
}
}
void DigitalSort2(list *&head) {
queue Q[257];
for (int i = 0; i < 257; i++) {
Q[i].tail = (list *) &(Q[i].head);
}
list *p;
for (int j = 30; j >= 0; j--) {
for (int i = 0; i < 256; i++) {
Q[i].tail = Q[i].head = NULL;
}
while (head) {
int d;
d = head->Data->a[j] + 129;
p = Q[d].tail;
if (Q[d].head == NULL) {
Q[d].head = head;
} else {
p->next = head;
}
p = Q[d].tail = head;
head = head->next;
p->next = NULL;
}
head = NULL;
int i;
for (i = 0; i < 256; i++) {
if (Q[i].head != NULL) {
break;
}
}
head = Q[i].head;
p = Q[i].tail;
for (int k = i + 1; k < 256; k++) {
if (Q[k].head != NULL) {
p->next = Q[k].head;
p = Q[k].tail;
}
}
}
}
void deleteList(list *head) {
do {
list *q;
q = head;
head = q->next;
delete (q);
} while (head != NULL);
}
void DigitalSort(queue *S, int L) {
queue Q[B];
list *p;
for (int j = 0; j < L; j++) {
for (int i = 0; i < B; i++) Q[i].tail = (list *) &Q[i].head;
p = S->head;
while (p) {
int d = p->Data->Digit[j];
Q[d].tail->next = p;
Q[d].tail = p;
p = p->next;
}
p = (list *) &S->head;
for (int i = 0; i < B; i++) {
if (Q[i].tail != (list *) &Q[i].head) {
p->next = Q[i].head;
p = Q[i].tail;
}
}
p->next = NULL;
}
}
void RL(Vertex *&p, Vertex *&r, Vertex *&q) {
q = p->right;//RL
r = q->left;
if (r->Bal < 0) p->Bal = 1;
else p->Bal = 0;
if (r->Bal > 0) q->Bal = -1;
else {
q->Bal = 0;
r->Bal = 0;
q->left = r->right;
p->right = r->left;
r->right = q;
r->left = p;
p = r;
Rost = false;
}
}
void RR(Vertex *&p, Vertex *&r, Vertex *&q) {
q = p->right;//RR
p->Bal = 0;
q->Bal = 0;
p->right = q->left;
q->left = p;
p = q;
Rost = false;
}
void LR(Vertex *&p, Vertex *&r, Vertex *&q) {
q = p->left;//LR
r = q->right;
if (r->Bal < 0) p->Bal = 1;
else p->Bal = 0;
if (r->Bal > 0) q->Bal = -1;
else {
q->Bal = 0;
r->Bal = 0;
q->right = r->left;
p->left = r->right;
r->left = q;
r->right = p;
p = r;
Rost = false;
}
}
void LL(Vertex *&p, Vertex *&r, Vertex *&q) {
q = p->left;//LL
p->Bal = 0;
q->Bal = 0;
p->left = q->right;
q->right = p;
p = q;
Rost = false;
}
Vertex *AVL(list *k, Vertex *&p) {
Vertex *q = NULL, *r = NULL;
if (p == NULL) {
p = new Vertex;
p->Data = (k->Data);
p->left = p->right = NULL;
p->Bal = 0;
Rost = true;
} else if (p->Data->d > k->Data->d) {
AVL(k, p->left);
if (Rost) {
if (p->Bal > 0) {
p->Bal = 0;
Rost = false;
} else if (p->Bal == 0) {
p->Bal = -1;
Rost = true;
} else if (p->left->Bal < 0)
LL(p, r, q);
else LR(p, r, q);
}
} else if (p->Data->d < k->Data->d) {
AVL(k, p->right);
if (Rost) {
if (p->Bal < 0) {
p->Bal = 0;
Rost = false;
} else if (p->Bal == 0) {
p->Bal = 1;
Rost = true;
} else if (p->right->Bal > 0) RR(p, r, q);
else
RL(p, r, q);
}
} else return p;
}
void obhod(Vertex *p) {
if (p != NULL) {
obhod(p->left);
cout<<" "<<p->Data->d;
obhod(p->right);
}
}
int main() {
FILE *input;
queue q;
Vertex *root = NULL;
input
= fopen("testBase3.dat", "rb"); record2 *mas2;
mas2 = new record2[n];
int i = 0;
list *head, *p, *r;
q.head = p = new list;
p->Data = new record2;
fread((record2
*) p
->Data
, sizeof(record2
), 1, input
);
for (i = 1; i < n; i++) {
p = p->next = new list;
p->Data = new record2;
fread((record2
*) p
->Data
, sizeof(record2
), 1, input
); }
p->next = NULL;
q.tail = p;
int *key = new int[3];
/*for (i = 0; i < 3; i++) {
char my_key = 0;
scanf("%c", &my_key);
key[i]=(int)my_key;
}*/
DigitalSort(&q, 2);
DigitalSort2(q.head);
// PrintList(q.head);
r=q.head;
i=0;
while(i<1000)
{
i++;
AVL(r,root);
r=r->next;
}
obhod(root);
delete (mas2);
deleteList(q.head);
return 0;
}
#define _CRT_SECURE_NO_DEPRECATE

#include <cstring>
#include <cstdlib>
#include <iostream>
#include <conio.h>


using namespace std;
const int n = 4000;
const int B = 256;
struct record2 {
    char a[30];
    union {
        unsigned short int b;
        unsigned char Digit[2];
    };

    char c[10];
    char d[22];
};

struct Vertex {
    record2 *Data;
    int Bal;
    Vertex *left;
    Vertex *right;
};
bool Rost;
bool Decrease;



struct list {
    list *next;
    record2 *Data;
};

typedef struct queue {
    list *head;
    list *tail;
};

void PrintList(list *p) {
    int i = 1;
    char c = 'y';

    while (c == 'y') {
        for (int j = 0; j < 20; j++) {
            printf("%d %s %d %s %s \n", i, p->Data->a, p->Data->b, p->Data->c, p->Data->d);
            p = p->next;
            i++;
        }

        c = '0';
        while ((c != 'y') && (c != 'n')) {
            c = '0';
            printf("\n\nPrint next 20 records? y/n\n");
            scanf("%s", &c);
            if ((c != 'y') && (c != 'n')) printf("Invalid input\n");
        }

    }


    if (c == 'n') {
        do {
            while ((_kbhit() != 1) && (p != NULL)) {
                printf("%d %s %d %s %s \n", i, p->Data->a, p->Data->b, p->Data->c, p->Data->d);
                p = p->next;
                i++;
            }
            system("PAUSE");
        } while (p != NULL);
    }


}


void DigitalSort2(list *&head) {

    queue Q[257];

    for (int i = 0; i < 257; i++) {
        Q[i].tail = (list *) &(Q[i].head);
    }

    list *p;


    for (int j = 30; j >= 0; j--) {
        for (int i = 0; i < 256; i++) {
            Q[i].tail = Q[i].head = NULL;
        }
        while (head) {
            int d;
            d = head->Data->a[j] + 129;
            p = Q[d].tail;
            if (Q[d].head == NULL) {
                Q[d].head = head;
            } else {
                p->next = head;
            }
            p = Q[d].tail = head;
            head = head->next;
            p->next = NULL;
        }
        head = NULL;
        int i;
        for (i = 0; i < 256; i++) {
            if (Q[i].head != NULL) {
                break;
            }
        }
        head = Q[i].head;
        p = Q[i].tail;
        for (int k = i + 1; k < 256; k++) {
            if (Q[k].head != NULL) {
                p->next = Q[k].head;
                p = Q[k].tail;
            }
        }
    }
}

void deleteList(list *head) {
    do {
        list *q;
        q = head;
        head = q->next;
        delete (q);
    } while (head != NULL);

}


void DigitalSort(queue *S, int L) {
    queue Q[B];
    list *p;

    for (int j = 0; j < L; j++) {
        for (int i = 0; i < B; i++) Q[i].tail = (list *) &Q[i].head;
        p = S->head;
        while (p) {
            int d = p->Data->Digit[j];
            Q[d].tail->next = p;
            Q[d].tail = p;
            p = p->next;
        }
        p = (list *) &S->head;

        for (int i = 0; i < B; i++) {
            if (Q[i].tail != (list *) &Q[i].head) {
                p->next = Q[i].head;
                p = Q[i].tail;
            }
        }

        p->next = NULL;
    }
}

void RL(Vertex *&p, Vertex *&r, Vertex *&q) {

    q = p->right;//RL
    r = q->left;
    if (r->Bal < 0) p->Bal = 1;
    else p->Bal = 0;
    if (r->Bal > 0) q->Bal = -1;
    else {
        q->Bal = 0;
        r->Bal = 0;
        q->left = r->right;
        p->right = r->left;
        r->right = q;
        r->left = p;
        p = r;
        Rost = false;
    }
}


void RR(Vertex *&p, Vertex *&r, Vertex *&q) {
    q = p->right;//RR
    p->Bal = 0;
    q->Bal = 0;
    p->right = q->left;
    q->left = p;
    p = q;
    Rost = false;
}

void LR(Vertex *&p, Vertex *&r, Vertex *&q) {
    q = p->left;//LR
    r = q->right;
    if (r->Bal < 0) p->Bal = 1;
    else p->Bal = 0;
    if (r->Bal > 0) q->Bal = -1;
    else {
        q->Bal = 0;
        r->Bal = 0;
        q->right = r->left;
        p->left = r->right;
        r->left = q;
        r->right = p;
        p = r;
        Rost = false;
    }
}

void LL(Vertex *&p, Vertex *&r, Vertex *&q) {
    q = p->left;//LL
    p->Bal = 0;
    q->Bal = 0;
    p->left = q->right;
    q->right = p;
    p = q;
    Rost = false;
}

Vertex *AVL(list *k, Vertex *&p) {

        Vertex *q = NULL, *r = NULL;

        if (p == NULL) {
            p = new Vertex;
            p->Data = (k->Data);
            p->left = p->right = NULL;
            p->Bal = 0;
            Rost = true;
        } else if (p->Data->d > k->Data->d) {
            AVL(k, p->left);
            if (Rost) {
                if (p->Bal > 0) {
                    p->Bal = 0;
                    Rost = false;
                } else if (p->Bal == 0) {
                    p->Bal = -1;
                    Rost = true;
                } else if (p->left->Bal < 0)
                    LL(p, r, q);
                else LR(p, r, q);
            }
        } else if (p->Data->d < k->Data->d) {
            AVL(k, p->right);
            if (Rost) {
                if (p->Bal < 0) {
                    p->Bal = 0;
                    Rost = false;
                } else if (p->Bal == 0) {
                    p->Bal = 1;
                    Rost = true;
                } else if (p->right->Bal > 0) RR(p, r, q);
                else
                    RL(p, r, q);
            }
        } else return p;
    }



void obhod(Vertex *p) {
    if (p != NULL) {
        obhod(p->left);
        cout<<" "<<p->Data->d;
        obhod(p->right);
    }
}


int main() {

    FILE *input;
    queue q;
    Vertex *root = NULL;
    input = fopen("testBase3.dat", "rb");
    record2 *mas2;
    mas2 = new record2[n];
    int i = 0;

    list *head, *p, *r;
    q.head = p = new list;

    p->Data = new record2;
    fread((record2 *) p->Data, sizeof(record2), 1, input);

    for (i = 1; i < n; i++) {
        p = p->next = new list;
        p->Data = new record2;
        fread((record2 *) p->Data, sizeof(record2), 1, input);
    }
    p->next = NULL;
    q.tail = p;
    int *key = new int[3];
    /*for (i = 0; i < 3; i++) {
        char my_key = 0;
        scanf("%c", &my_key);
        key[i]=(int)my_key;
    }*/


    DigitalSort(&q, 2);
    DigitalSort2(q.head);
   // PrintList(q.head);
      r=q.head;
i=0;
       while(i<1000)
      {
          i++;
          AVL(r,root);
          r=r->next;

      }
     obhod(root);

    delete (mas2);
    deleteList(q.head);
    return 0;
}