Home >Backend Development >C++ >C program for radix sort

C program for radix sort

PHPz
PHPzforward
2023-09-02 22:17:05589browse

Sort algorithm is an algorithm that arranges the components of a list in a specific order. The most commonly used orders are numerical order and dictionary order.

Cardix Sorting is a non-comparative sorting algorithm. The radix sort algorithm is the preferred algorithm for unsorted lists.

It sorts elements by initially grouping individual numbers of the same place value. The idea of ​​radix sort is to sort bit by bit from least significant digit (LSD) to most significant digit (MSD) in increasing/decreasing order. Radix sort is a small method that is used many times when sorting very large lists of names alphabetically. Specifically, the name list was initially sorted according to the first letter of each name, i.e., the names were organized into twenty-six categories.

Let us review the illustration below to get a clear understanding of how the radix sort algorithm works. Obviously, the number of passes/iterations depends on the size of the highest individual number.

C program for radix sort

In the above example, the main column is entered. The remaining columns show A sequentially sorted list of numerical positions of increasing importance.

Complexity analysis of radix sort O(m.n).

However, if we look at both values, the size of the keys is relatively small compared to the number of keys. For example, if we had a six-digit key, we could have 1,000,000 completely different records.

Here we tend to see that the size of the key does not matter and the algorithm is linear quality O(n)

Algorithm

Radix_sort (list, n)
shift = 1
for loop = 1 to keysize do
   for entry = 1 to n do
   bucketnumber = (list[entry].key / shift) mod 10
   append (bucket[bucketnumber], list[entry])
list = combinebuckets()
shift = shift * 10

Example

This is a C program that implements radix sorting.

Live demonstration

#include<stdio.h>
int get_max (int a[], int n){
   int max = a[0];
   for (int i = 1; i < n; i++)
      if (a[i] > max)
         max = a[i];
   return max;
}
void radix_sort (int a[], int n){
   int bucket[10][10], bucket_cnt[10];
   int i, j, k, r, NOP = 0, divisor = 1, lar, pass;
   lar = get_max (a, n);
   while (lar > 0){
      NOP++;
      lar /= 10;
   }
   for (pass = 0; pass < NOP; pass++){
      for (i = 0; i < 10; i++){
         bucket_cnt[i] = 0;
      }
      for (i = 0; i < n; i++){
         r = (a[i] / divisor) % 10;
         bucket[r][bucket_cnt[r]] = a[i];
         bucket_cnt[r] += 1;
      }
      i = 0;
      for (k = 0; k < 10; k++){
         for (j = 0; j < bucket_cnt[k]; j++){
            a[i] = bucket[k][j];
            i++;
         }
      }
      divisor *= 10;
      printf ("After pass %d : ", pass + 1);
      for (i = 0; i < n; i++)
         printf ("%d ", a[i]);
      printf ("</p><p>");
   }
}
int main (){
   int i, n, a[10];
   printf ("Enter the number of items to be sorted: ");
   scanf ("%d", &n);
   printf ("Enter items: ");
   for (i = 0; i < n; i++){
      scanf ("%d", &a[i]);
   }
   radix_sort (a, n);
   printf ("Sorted items : ");
   for (i = 0; i < n; i++)
      printf ("%d ", a[i]);
   printf ("</p><p>");
   return 0;
}

Output

Enter number of items to be sorted 6
Enter items:567 789 121 212 563 562
After pass 1 : 121 212 562 563 567 789
After pass 2 : 212 121 562 563 567 789
After pass 3 : 121 212 562 563 567 789
Sorted items : 121 212 562 563 567 789

The above is the detailed content of C program for radix sort. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:tutorialspoint.com. If there is any infringement, please contact admin@php.cn delete