i have implemented counting sort according pseudocode ( that's written on blackboard in video explanation ) mysterious reason, doesn't seem sort properly.
for test input: 10 9 8 7 6 5 4 3 2 1
it gives: 3 4 5 6 7 8 1 0 0 9
it seems simple problem can't figure out why happening.
void counting(int * array, int n){ int *copy, *out, i,j, max, counter; copy = (int*) malloc(sizeof(int) * max); out = (int*) malloc(sizeof(int) * n ); max = array[0]; // finds max size for(i=0;i<n;++i) if(array[i] > max) max = array[i]; // zeroes counting array for(i=0;i<max;++i) copy[i] = 0; //counts for(i=0;i<n;++i) ++copy[array[i]]; //cumulative sum for(i=1;i<max;++i) copy[i] += copy[i-1]; //sorts for(i=n-1;i>=1;--i){ out[copy[array[i]]] = array[i]; --copy[array[i]]; } //overwrite original array sorted output for(i=0;i<n;++i) array[i] = out[i]; }
the problem order in allocate array of counters: when write
copy = (int*) malloc(sizeof(int) * max);
the max
not set, value undefined. therefore, allocation produces undefined behavior, making program invalid.
you need move allocation past loop computes max
. allocate max+1
items, because array indexes zero-based:
int max = array[0]; for(i=0;i<n;++i) if(array[i] > max) max = array[i]; copy = malloc(sizeof(int) * (max+1));
you need free
both copy
, out
@ end avoid memory leaks:
free(copy); free(out);
Comments
Post a Comment