Source code:
priorityqueue_t * pqueue_create() {
priorityqueue_t *pq;
pq = (priorityqueue_t *) malloc(sizeof(priorityqueue_t));
pq->entries = (pqentry_t **) malloc(4 * sizeof(pqentry_t *));
pq->last = 0;
pq->size = 4;
return pq;
}
void pqueue_insert(priorityqueue_t *pq, char* value, float p) {
if (isFull(pq)) {
pq->size *= 2;
pq->entries = realloc(pq->entries, pq->size * sizeof(pqentry_t *));
}
pqentry_t *eintrag = malloc(sizeof(pqentry_t));
eintrag->pqvalue = (char *) malloc(sizeof(value));
eintrag->pqvalue = strcpy(eintrag->pqvalue,value);
//eintrag->pqvalue = value;
eintrag->priotity = p;
//hinten einfügen und einsortieren
pq->entries[pq->last] = eintrag;
pq->last += 1;
sortIn(pq,pq->last - 1);
}
static void sortIn (priorityqueue_t *pq, int pos) {
if (pos >= 1) {
for (int i = pos; i > 0; --i) {
if (pq->entries[i-1]->priotity > pq->entries[i]->priotity) {
pqentry_t *swap = pq->entries[i-1];
pq->entries[i-1] = pq->entries[i];
pq->entries[i] = swap;
}
}
}
}
Main code:
char* randomString (int size) {
char* str = (char *) malloc((size+1)* sizeof(char));
for (int i = 0; i < size; ++i) {
str[i] = (rand() % 26) + 'A';
}
str[size] = '\0';
return str;
}
int main() {
int i;
char* strings[MAX];
clock_t tic, toc;
srand(time(NULL));
for (i = 0; i < MAX; ++i) {
strings[i] = randomString(8);
}
priorityqueue_t *pq = pqueue_create();
tic = clock();
for (i = 0; i < MAX; i++){
pqueue_insert(pq,strings[i],rand() % 100);
}
toc = clock();
printf("insertion time: %.2f \n", (float) (toc-tic) / CLOCKS_PER_SEC);
tic = clock();
for (i = 0; i < MAX; i++){
pqueue_extractMin(pq);
}
toc = clock();
printf("extraction time: %.2f \n", (float) (toc-tic) / CLOCKS_PER_SEC);
for (i = 0; i < MAX; ++i) {
free(strings[i]);
}
pqueue_destroy(pq);
return 0;
}
My problem is that the program crashes when I try to insert a second time in the for loop. Ironically, it works when I do it manually or run the program on my laptop. I'm happy about all help.
You aren't allocating enough space in this line:
eintrag->pqvalue = (char *) malloc(sizeof(value));
That's because value
is passed into pqueue_insert
as a char*
, so the compile time evaluation of the sizeof
operator isn't allocating enough space for you. Try changing the allocation to:
eintrag->pqvalue = malloc(1 + strlen(value));
Note that the C spec defines how big a char
is, i.e. 1 byte, so you don't need a sizeof(char) here.