#include <stdio.h>
#include <stdlib.h>
#define HASH_SIZE 4019
struct Person {
char first_name[20];
char last_name[20];
char dob[11];
double balance;
};
struct HashNode {
struct Person *person;
struct HashNode *next;
};
struct HashTable {
struct HashNode *table[HASH_SIZE];
};
unsigned int hash(char *string) {
unsigned int result = 0;
for (int i = 0; string[i] != '\0'; i++) {
result = 33 * result + string[i];
}
return result % HASH_SIZE;
}
void custom_strcpy(char *dest, const char *src) {
int i = 0;
while (src[i] != '\0') {
dest[i] = src[i];
i++;
}
dest[i] = '\0';
}
int custom_strcmp(const char *str1, const char *str2) {
while (*str1 && (*str1 == *str2)) {
str1++;
str2++;
}
return *(unsigned char *)str1 - *(unsigned char *)str2;
}
void insert(struct HashTable *hash_table, struct Person *person, int *counter) {
unsigned int index = hash(person->first_name) + hash(person->last_name) + hash(person->dob);
index %= HASH_SIZE;
struct HashNode
*new_node
= malloc(sizeof(struct HashNode
)); new_node->person = person;
new_node->next = NULL;
if (hash_table->table[index] == NULL) {
hash_table->table[index] = new_node;
} else {
struct HashNode *current = hash_table->table[index];
while (current->next != NULL) {
if (custom_strcmp(current->person->first_name, person->first_name) == 0 &&
custom_strcmp(current->person->last_name, person->last_name) == 0 &&
custom_strcmp(current->person->dob, person->dob) == 0) {
if(*counter == 0) {
}
else{
}
(*counter)++;
return;
}
current = current->next;
}
if (custom_strcmp(current->person->first_name, person->first_name) == 0 &&
custom_strcmp(current->person->last_name, person->last_name) == 0 &&
custom_strcmp(current->person->dob, person->dob) == 0) {
if(*counter == 0) {
}
else{
}
(*counter)++;
return;
}
current->next = new_node;
}
}
struct Person *search(struct HashTable *hash_table, char *first_name, char *last_name, char *dob) {
unsigned int index = hash(first_name) + hash(last_name) + hash(dob);
index %= HASH_SIZE;
struct HashNode *current = hash_table->table[index];
while (current != NULL) {
if (custom_strcmp(current->person->first_name, first_name) == 0 &&
custom_strcmp(current->person->last_name, last_name) == 0 &&
custom_strcmp(current->person->dob, dob) == 0) {
return current->person;
}
current = current->next;
}
return NULL;
}
void update(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, double new_balance, int *counter) {
struct Person *person = search(hash_table, first_name, last_name, dob);
if (person != NULL) {
if(person->balance + new_balance <0){
if(*counter == 0) {
}
else{
}
(*counter)++;
}else{
person->balance += new_balance;
}
} else {
if(*counter == 0) {
}
else{
}
(*counter)++;
}
}
void delete(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, int *counter) {
unsigned int index = hash(first_name) + hash(last_name) + hash(dob);
index %= HASH_SIZE;
struct HashNode *current = hash_table->table[index];
struct HashNode *prev = NULL;
while (current != NULL) {
if (custom_strcmp(current->person->first_name, first_name) == 0 &&
custom_strcmp(current->person->last_name, last_name) == 0 &&
custom_strcmp(current->person->dob, dob) == 0) {
if (prev == NULL) {
hash_table->table[index] = current->next;
} else {
prev->next = current->next;
}
return;
}
prev = current;
current = current->next;
}
if(*counter == 0) {
}
else{
}
(*counter)++;
}
void print_balance(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, int *counter) {
struct Person *person = search(hash_table, first_name, last_name, dob);
if (person != NULL) {
double balance = person->balance;
int integer_part = (int)balance;
double fractional_part = balance - integer_part;
int rounded_fraction = (int)((fractional_part + 0.005) * 100);
if(*counter == 0) {
printf("%d,%02d", integer_part
, rounded_fraction
); }
else{
printf("\n%d,%02d", integer_part
, rounded_fraction
); }
(*counter)++;
} else {
if(*counter == 0) {
}
else{
}
(*counter)++;
}
}
int main() {
struct HashTable hash_table;
for (int i = 0; i < HASH_SIZE; ++i) {
hash_table.table[i] = NULL;
}
char op;
char first_name[20], last_name[20], dob[11];
int whole;
double balance;
int counter = 0;
while (scanf(" %c", &op
) == 1) { switch (op) {
case 'i':
scanf("%s %s %s %d,%lf", first_name
, last_name
, dob
, &whole
, &balance
); if(whole<0){
balance = whole - balance / 100;
}
else{
balance = whole + balance / 100;
}
if (balance < 0) {
break;
}
struct Person
*person
= malloc(sizeof(struct Person
));
custom_strcpy(person->first_name, first_name);
custom_strcpy(person->last_name, last_name);
custom_strcpy(person->dob, dob);
person->balance = balance;
insert(&hash_table, person, &counter);
break;
case 's':
scanf("%s %s %s", first_name
, last_name
, dob
); print_balance(&hash_table, first_name, last_name, dob, &counter);
break;
case 'u':
scanf("%s %s %s %d,%lf", first_name
, last_name
, dob
, &whole
, &balance
); if(whole<0){
balance = whole - balance / 100;
}
else{
balance = whole + balance / 100;
}
update(&hash_table, first_name, last_name, dob, balance, &counter);
break;
case 'd':
scanf("%s %s %s", first_name
, last_name
, dob
); delete(&hash_table, first_name, last_name, dob,&counter);
break;
default:
break;
}
}
for (int i = 0; i < HASH_SIZE; ++i) {
struct HashNode *current = hash_table.table[i];
while (current != NULL) {
struct HashNode *temp = current;
current = current->next;
}
}
return 0;
}
#include <stdio.h>
#include <stdlib.h>


#define HASH_SIZE 4019

struct Person {
    char first_name[20];
    char last_name[20];
    char dob[11];
    double balance;
};

struct HashNode {
    struct Person *person;
    struct HashNode *next;
};

struct HashTable {
    struct HashNode *table[HASH_SIZE];
};


unsigned int hash(char *string) {
    unsigned int result = 0;
    for (int i = 0; string[i] != '\0'; i++) {
        result = 33 * result + string[i];
    }
    return result % HASH_SIZE;
}
void custom_strcpy(char *dest, const char *src) {
    int i = 0;
    while (src[i] != '\0') {
        dest[i] = src[i];
        i++;
    }
    dest[i] = '\0';
}

int custom_strcmp(const char *str1, const char *str2) {
    while (*str1 && (*str1 == *str2)) {
        str1++;
        str2++;
    }
    return *(unsigned char *)str1 - *(unsigned char *)str2;
}



void insert(struct HashTable *hash_table, struct Person *person, int *counter) {
    unsigned int index = hash(person->first_name) + hash(person->last_name) + hash(person->dob);
    index %= HASH_SIZE;

    struct HashNode *new_node = malloc(sizeof(struct HashNode));
    new_node->person = person;
    new_node->next = NULL;

    if (hash_table->table[index] == NULL) {
        hash_table->table[index] = new_node;
    } else {
        struct HashNode *current = hash_table->table[index];
        while (current->next != NULL) {
            if (custom_strcmp(current->person->first_name, person->first_name) == 0 &&
                custom_strcmp(current->person->last_name, person->last_name) == 0 &&
                custom_strcmp(current->person->dob, person->dob) == 0) {
                if(*counter == 0) {
                    printf("insert failed");
                }
                else{
                    printf("\ninsert failed");
                }
                (*counter)++;
                free(new_node->person);
                free(new_node);
                return;
            }
            current = current->next;
        }
        if (custom_strcmp(current->person->first_name, person->first_name) == 0 &&
            custom_strcmp(current->person->last_name, person->last_name) == 0 &&
            custom_strcmp(current->person->dob, person->dob) == 0) {
            if(*counter == 0) {
                printf("insert failed");
            }
            else{
                printf("\ninsert failed");
            }
            (*counter)++;
            free(new_node->person);
            free(new_node);
            return;
        }
        current->next = new_node;
    }
}



struct Person *search(struct HashTable *hash_table, char *first_name, char *last_name, char *dob) {
    unsigned int index = hash(first_name) + hash(last_name) + hash(dob);
    index %= HASH_SIZE;

    struct HashNode *current = hash_table->table[index];
    while (current != NULL) {
        if (custom_strcmp(current->person->first_name, first_name) == 0 &&
            custom_strcmp(current->person->last_name, last_name) == 0 &&
            custom_strcmp(current->person->dob, dob) == 0) {
            return current->person;
        }
        current = current->next;
    }
    return NULL;
}

void update(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, double new_balance, int *counter) {
    struct Person *person = search(hash_table, first_name, last_name, dob);
    if (person != NULL) {
        if(person->balance + new_balance <0){
            if(*counter == 0) {
                printf("update failed");
            }
            else{
                printf("\nupdate failed");
            }
            (*counter)++;
        }else{
            person->balance += new_balance;
        }

    } else {
        if(*counter == 0) {
            printf("update failed");
        }
        else{
            printf("\nupdate failed");
        }
        (*counter)++;
    }
}

void delete(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, int *counter) {
    unsigned int index = hash(first_name) + hash(last_name) + hash(dob);
    index %= HASH_SIZE;

    struct HashNode *current = hash_table->table[index];
    struct HashNode *prev = NULL;

    while (current != NULL) {
        if (custom_strcmp(current->person->first_name, first_name) == 0 &&
            custom_strcmp(current->person->last_name, last_name) == 0 &&
            custom_strcmp(current->person->dob, dob) == 0) {
            if (prev == NULL) {
                hash_table->table[index] = current->next;
            } else {
                prev->next = current->next;
            }
            free(current->person);
            free(current);
            return;
        }
        prev = current;
        current = current->next;
    }
    if(*counter == 0) {
        printf("delete failed");
    }
    else{
        printf("\ndelete failed");
    }
    (*counter)++;
}
void print_balance(struct HashTable *hash_table, char *first_name, char *last_name, char *dob, int *counter) {
    struct Person *person = search(hash_table, first_name, last_name, dob);
    if (person != NULL) {
        double balance = person->balance;
        int integer_part = (int)balance;
        double fractional_part = balance - integer_part;

        int rounded_fraction = (int)((fractional_part + 0.005) * 100);

        if(*counter == 0) {
            printf("%d,%02d", integer_part, rounded_fraction);
        }
        else{
            printf("\n%d,%02d", integer_part, rounded_fraction);
        }
        (*counter)++;
    } else {
        if(*counter == 0) {
            printf("search failed");
        }
        else{
            printf("\nsearch failed");
        }
        (*counter)++;
    }
}




int main() {
    struct HashTable hash_table;
    for (int i = 0; i < HASH_SIZE; ++i) {
        hash_table.table[i] = NULL;
    }

    char op;
    char first_name[20], last_name[20], dob[11];
    int whole;
    double balance;
    int counter = 0;

    while (scanf(" %c", &op) == 1) {
        switch (op) {
            case 'i':
                scanf("%s %s %s %d,%lf", first_name, last_name, dob, &whole, &balance);
                if(whole<0){
                    balance = whole - balance / 100;
                }
                else{
                    balance = whole + balance / 100;
                }
                if (balance < 0) {
                    printf("insert failed\n");
                    break;
                }
                struct Person *person = malloc(sizeof(struct Person));

                custom_strcpy(person->first_name, first_name);
                custom_strcpy(person->last_name, last_name);
                custom_strcpy(person->dob, dob);
                person->balance = balance;
                insert(&hash_table, person, &counter);
                break;
            case 's':
                scanf("%s %s %s", first_name, last_name, dob);
                print_balance(&hash_table, first_name, last_name, dob, &counter);
                break;
            case 'u':
                scanf("%s %s %s %d,%lf", first_name, last_name, dob, &whole, &balance);
                if(whole<0){
                    balance = whole - balance / 100;
                }
                else{
                    balance = whole + balance / 100;
                }
                update(&hash_table, first_name, last_name, dob, balance, &counter);
                break;
            case 'd':
                scanf("%s %s %s", first_name, last_name, dob);
                delete(&hash_table, first_name, last_name, dob,&counter);
                break;
            default:
                break;
        }
    }

    for (int i = 0; i < HASH_SIZE; ++i) {
        struct HashNode *current = hash_table.table[i];
        while (current != NULL) {
            struct HashNode *temp = current;
            current = current->next;
            free(temp->person);
            free(temp);
        }
    }

    return 0;
}

