Looks like removing top works.

master
Tomasz Polgrabia 2025-02-09 01:40:55 +01:00
parent dc1fa3f381
commit 9002bf7afb
1 changed files with 78 additions and 17 deletions

View File

@ -1,3 +1,4 @@
#include <limits.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
@ -111,40 +112,99 @@ void dump_heap(list *q) {
}
}
list* node_add(list *q, long key) {
list *c = NULL;
list *a = q;
node *b = node_create(key);
list *bl;
list* node_union(list *q, node *b) {
list *bl,*a = q, *c;
if (!q) {
a = (list*)malloc(sizeof(list));
a->node = b;
return a;
bl = (list*)malloc(sizeof(list));
bl->node = b;
return bl;
}
int added = 0;
bl = a;
while (a) {
if (a->node->lvl > b->lvl) { // it a always will be bigger or equal
list *el = (list*)malloc(sizeof(list));
el->node = b;
el->next = a;
return el;
} else {
c = a->next;
} if (a->node->lvl == b->lvl) {
a->node = node_union_same_lvl(a->node, b);
bl = a;
b = a->node;
a = c;
a = a->next;
added++;
} else {
bl = a;
a = a->next;
}
}
return bl;
if (!added) {
list *el = (list*)malloc(sizeof(list));
el->node = b;
el->next = NULL;
bl->next = el;
return q;
} else {
return bl;
}
}
int node_del(node *q) {
// TODO
return -1;
list* node_add(list *q, long key) {
node *b = node_create(key);
return node_union(q, b);
}
int node_del(list **q) {
list *t = *q;
long maxValue = INT_MIN;
node *maxTree = NULL;
while (t) {
if (!maxTree || t->node->key > maxValue) {
maxValue = t->node->key;
maxTree = t->node;
}
t = t->next;
}
// we have max element and tree now
t = *q;
if (t->node == maxTree) {
printf("Removed maxtree is the beginning\n");
t = t->next;
} else {
printf("Removed maxtree is not the beginning\n");
while (t && t->next && t->next->node != maxTree) {
t = t->next;
}
t->next = t->next->next;
}
printf("New list pointer 0x%x\n", t);
// we removed the maxTree from the list
node *c = maxTree->child;
node *b;
while (c) {
b = c->right;
c->right = NULL;
t = node_union(t, c);
c = b;
}
*q = t;
return maxValue;
}
@ -175,8 +235,9 @@ int main() {
fprintf(stderr, "There is nothing to delete - heap is empty\n");
continue;
}
// TODO: long key = node_del(q);
// printf("Removed element: %d\n", key);
long key = node_del(&q);
printf("Removed element: %d\n", key);
} else {
// handle unknown command
fprintf(stderr, "Got unknown command %s\n", cmd);