/* File: serial_count_sort1.c * * Purpose: Use count sort to sort a list of ints (but see note). * * Usage: ./count_sort * n: number of elements in list * 'g': generate list using a random number generator * 'i': user input list * * Input: list (optional) * Output: sorted list * * Note: * 1. This version will only work if the elements of the list are distinct */ #include #include const int RMAX = 20; void Usage(char* prog_name); void Get_args(int argc, char* argv[], int* n_p, char* g_i_p); void Generate_list(int a[], int n); void Print_list(int a[], int n, char* title); void Read_list(int a[], int n); void Count_sort(int a[], int n); /*-----------------------------------------------------------------*/ int main(int argc, char* argv[]) { int n; char g_i; int* a; Get_args(argc, argv, &n, &g_i); a = malloc(n*sizeof(int)); if (g_i == 'g') { Generate_list(a, n); Print_list(a, n, "Before sort"); } else { Read_list(a, n); } Count_sort(a, n); Print_list(a, n, "After sort"); free(a); return 0; } /* main */ /*----------------------------------------------------------------- * Function: Usage * Purpose: Summary of how to run program */ void Usage(char* prog_name) { fprintf(stderr, "usage: %s \n", prog_name); fprintf(stderr, " n: number of elements in list\n"); fprintf(stderr, " 'g': generate list using a random number generator\n"); fprintf(stderr, " 'i': user input list\n"); } /* Usage */ /*----------------------------------------------------------------- * Function: Get_args * Purpose: Get and check command line arguments * In args: argc, argv * Out args: n_p, g_i_p */ void Get_args(int argc, char* argv[], int* n_p, char* g_i_p) { if (argc != 3 ) { Usage(argv[0]); exit(0); } *n_p = strtol(argv[1], NULL, 10); *g_i_p = argv[2][0]; if (*n_p <= 0 || (*g_i_p != 'g' && *g_i_p != 'i') ) { Usage(argv[0]); exit(0); } } /* Get_args */ /*----------------------------------------------------------------- * Function: Generate_list * Purpose: Use random number generator to generate list elements * In args: n * Out args: a */ void Generate_list(int a[], int n) { int i; srandom(1); for (i = 0; i < n; i++) a[i] = random() % RMAX; } /* Generate_list */ /*----------------------------------------------------------------- * Function: Print_list * Purpose: Print the elements in the list * In args: a, n */ void Print_list(int a[], int n, char* title) { int i; printf("%s:\n", title); for (i = 0; i < n; i++) printf("%d ", a[i]); printf("\n\n"); } /* Print_list */ /*----------------------------------------------------------------- * Function: Read_list * Purpose: Read elements of list from stdin * In args: n * Out args: a */ void Read_list(int a[], int n) { int i; printf("Please enter the elements of the list\n"); for (i = 0; i < n; i++) scanf("%d", &a[i]); } /* Read_list */ /*----------------------------------------------------------------- * Function: Count_sort * Purpose: Sort list using count sort * In args: n * In/out args: a * * Note: All elements of list must be distinct */ void Count_sort(int a[], int n) { int i, j, count; int* temp = malloc(n*sizeof(int)); for (i = 0; i < n; i++) { count = 0; for (j = 0; j < n; j++) if (a[j] < a[i]) count++; temp[count] = a[i]; } for (i = 0; i < n; i++) a[i] = temp[i]; free(temp); } /* Count_sort */