When this process is complete, the array elements that are still set to one
indicate that the subscript is a prime number. These subscripts can then be
printed. Write a program that uses an array of 1000 elements to determine and
print the prime numbers between 2 and \(999 .\) Ignore element 0 of the array.
(Bucket Sort) A bucket sort begins with a one-dimensional array of positive
integers to be sorted and a two-dimensional array of integers with rows
subscripted from 0 to 9 and columns subscripted from 0 to \(n 1\), where \(n\) is
the number of values in the array to be sorted. Each row of the twodimensional
array is referred to as a bucket. Write a function bucketsort that takes an
integer array and the array size as arguments and performs as follows:
a. Place each value of the one-dimensional array into a row of the bucket
array based on the value's ones digit. For example, 97 is placed in row 7,3 is
placed in row 3 and 100 is placed in row \(0 .\) This is called a "distribution
pass."
b. Loop through the bucket array row by row, and copy the values back to the
original array. This is called a "gathering pass." The new order of the
preceding values in the one-dimensional array is 100,3 and \(97 .\)
c. Repeat this process for each subsequent digit position (tens, hundreds,
thousands, etc.).
On the second pass, 100 is placed in row 0,3 is placed in row 0 (because 3 has
no tens digit) and 97 is placed in row \(9 .\) After the gathering pass, the
order of the values in the one-dimensional array is 100,3 and \(97 .\) On the
third pass, 100 is placed in row 1,3 is placed in row zero and 97 is placed in
row zero (after the 3 ). After the last gathering pass, the original array is
now in sorted order.
Note that the two-dimensional array of buckets is 10 times the size of the
integer array being sorted. This sorting technique provides better performance
than a insertion sort, but requires much more memory. The insertion sort
requires space for only one additional element of data. This is an example of
the spacetime trade-off: The bucket sort uses more memory than the insertion
sort, but performs better. This version of the bucket sort requires copying
all the data back to the original array on each pass. Another possibility is
to create a second two-dimensional bucket array and repeatedly swap the data
between the two bucket arrays.