Sort String in Descending order in C Program
Program Description:
Write a Program to Sort String in descending order in C programming language. The program will accept a string from the user and then sorts the given string characters in descending order.
Descending order refers to the descending order of string characters’ ASCII values.
Here is the List of ASCII Characters with ASCII Values
As we have already discussed in our earlier posts, The characters are stored in the form of ASCII Values. So we are going to compare the ASCII Values of each character to sort the string.
📢 This Program is part of the C String Practice Programs series
If we want to sort the string in Alphabetic order, We can simply convert the input string to either lower case or upper case characters, Then apply the bubble sort to sort the string in alphabetical order.
You can learn more about the string lower case to upper case conversion and vice-versa in the following posts.
- C Program to Convert Lower case string to Upper case string
- C Program to Convert Uppercase string to Lowercase string
Let’s look at the excepted input and output of the program.
Example Input and Output:
Input:
Enter a string : CProgramming
Output:
String before sort :CProgramming(Actual String)
String After sorting :rronmmiggaPC(Descending Order)
In the ASCII table, upper-case characters appear before lower-case characters. As a result, the if we sort the string in descending order the lowercase characters will appear first and followed by the uppercase characters.
Prerequisites:
It is recommended to know the C-Strings, C-Arrays, and Functions in C to better understand the following program.
We are going to look at a few methods to sort the string in C language and each program will be followed by a detailed step-by-step explanation and program output. We also provided instructions for compiling and running the program using your compiler.
We are going to use the bubble sort algorithm to sort the characters of the input string. Let’s look at the algorithm of the bubble sort technique.
Bubble Sort Algorithm to Sort String in Descending order:
Bubble sort is a basic sorting algorithm that iterates through the string elements repeatedly, compares adjacent elements, and swaps them if any of the elements are out of order.
The above process is repeated until no swaps are required, at which point the string is considered to be sorted.
Here is the algorithm for the bubble sort
- We have a character array/string named inputStr[] string with len length of characters.
- for i = 0 to len-1
- for j = 0 to len-i-1
- if inputStr[j] < inputStr[j+1]
- swap(inputStr[j], inputStr[j+1])
- if inputStr[j] < inputStr[j+1]
- for j = 0 to len-i-1
- Once the above loop is terminated, inputStr string will be sorted in descending order.
- print the results
📢The time complexity of the bubble sort it O(n2). So it will be good for small arrays, But not suitable for large arrays.
Sort String in Descending order in C Program Explanation:
- Declare a string named inputStr with the SIZE size to hold the input string. The SIZE is a global constant. which holds the max length of the inputStr. Please change this constant value if you want to use large strings.
- Take the input string from the user using the gets function and store it in the inputStr string.
- In order to use the bubble sort algorithm, We need to know the string length. So get the string length by using the strlen() library function. and save the string length in len variable. – i.e len = strlen(inputStr);
- Now, We need to sort the
inputStr string using the bubble sort. Bubble sort uses two for loops and swaps the adjacent elements if they are in the wrong order.
- Start the first for loop, Traverse from i=0 till the i<len-1
- Nested for loop, Iterate from j=0 till the len-i-1
- At Each iteration, Check if the inputStr[j] is less than the inputStr[j+1]. If it is true, Then Swap the inputStr[j] and inputStr[j+1] variables. – i.e (inputStr[j] < inputStr[j + 1])
- We are using a temporary variable temp to swap the elements. We can also use other methods like Swapping without using temporary variables
- Increment the variable j – j++
- Nested for loop, Iterate from j=0 till the len-i-1
- increment the variable i – i++
- Start the first for loop, Traverse from i=0 till the i<len-1
- Once the above two for loops are completed, The input string inputStr will be sorted in descending order.
- Print the resultant string on the console.
Program to Sort String in Descending order in C Language:
Here is the C Program to Sort the characters of a string in Descending order
As we are using the strlen() library function, We need to include the string.h header file.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
/*     program to sort characters of string in descending order in c     sillycodes.com */ #include <stdio.h> #include <string.h>  // Max SIZE of string const int SIZE = 100;  int main() {     // declare a string with 'SIZE'     char inputStr[SIZE];     int i, j, temp,len;      // get the string from the user     printf("Enter a string : ");     gets(inputStr);      printf("String before sort :%s(Actual String)\n", inputStr);         // Get the length of the inputStr     len = strlen(inputStr);      // Sort the string in descending order     // We will use the bubble sort     for (i = 0; i < len - 1; i++)     {         for (j = 0; j < len - i - 1; j++)         {             if (inputStr[j] < inputStr[j + 1])             {                 // Swap the elements using 'temp' variable                 temp = inputStr[j];                 inputStr[j] = inputStr[j + 1];                 inputStr[j + 1] = temp;             }         }     }      // Print the results     printf("String After sorting :%s(Descending Order)\n", inputStr);     return 0; } |
Program Output:
Let’s compile and run the program using GCC(Any compiler)
1 2 3 4 5 6 |
$ gcc sort-string-bubble.c $ ./a.out Enter a string : CProgramming String before sort :CProgramming(Actual String) String After sorting :rronmmiggaPC(Descending Order) $ |
In the above example, The input string is CProgrammingand the program sorted the string in descending order and presented the rronmmiggaPC as the output.
Here are a few more examples
1 2 3 4 5 6 7 8 9 10 |
$ ./a.out Enter a string : sillycodes String before sort :sillycodes(Actual String) String After sorting :yssolliedc(Descending Order) $ $ ./a.out Enter a string : aaabbbccc String before sort :aaabbbccc(Actual String) String After sorting :cccbbbaaa(Descending Order) $ |
As we can see from the above inputs and outputs, The program is properly sorting the string in descending order.
Program to Sort String in Descending order using functions in C Language:
Let’s update the above program to use a user-defined function to sort the string. We will move the bubble sort sorting logic to a user-defined function.
By using the functions we can define a function once and can call it as many times as we want. Functions also increase the readability of the program and make it easier to debug issues. Here are the Advantages of functions in programming.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
/*     program to sort characters of string in descending order in c using functions     sillycodes.com */ #include <stdio.h> #include <string.h>  // Max SIZE of string const int SIZE = 100;  /** * @brief  - Sort input string in Descending order using bubble sort * * @param str - Input String */ void bubbleSort(char * str) {     int i, j, temp, len;      // Get the length of the str     len = strlen(str);      // Sort the string in descending order     // We will use the bubble sort     for (i = 0; i < len - 1; i++)     {         for (j = 0; j < len - i - 1; j++)         {             if (str[j] < str[j + 1])             {                 // Swap the elements using 'temp' variable                 temp = str[j];                 str[j] = str[j + 1];                 str[j + 1] = temp;             }         }     }  }  int main() {     // declare a string with 'SIZE'     char str[SIZE];      // get the string from the user     printf("Enter a string : ");     gets(str);      printf("String before sort :%s(Actual String)\n", str);         // Call the bubbleSort() function with 'str'     bubbleSort(str);      // Print the results     printf("String After sorting :%s(Descending Order)\n", str);     return 0; } |
In the above program, we have defined a function named bubbleSort function. This function takes a string as input and sorts the characters of a string in descending order. Here is the prototype of the bubbleSort function – void bubbleSort(char * str)
To sort the input string, Call the bubbleSort() function with the input string from the main() function.
1 2 |
// Call the bubbleSort() function with 'str' bubbleSort(str); |
Finally, Display the results on the screen.
Program Output:
Compile and Run the program.
1 2 3 4 5 6 |
$ gcc sort-string-desc-func.c $ ./a.out Enter a string : AABBIILLWWQQQ String before sort :AABBIILLWWQQQ(Actual String) String After sorting :WWQQQLLIIBBAA(Descending Order) $ |
As we can see from the above output, The program is properly sorting the array.
Related Programs:
- C Tutorials Index
- C Programs Index
- C Program to Remove Trailing Whitespaces in a String
- C Program to Remove Extra Spaces between the Words in String
- C Program to Remove All Whitespaces in a String or Sentence
- C Program to Count Frequencies of each character in a string
- C Program to Find Highest Frequency character in a String
- C Program to Find Lowest Frequency Character in a String
- C Program to Remove Vowels from a String
- C Program to Remove Consonants from a String
2 Responses
[…] C Program to Sort String in Descending Order […]
[…] C Program to Sort String in Descending Order […]