Program to Compare Two Strings in C Programming
Program Description:
Write a Program to Compare Two Strings in C programming language. The program will accept two strings from the user and compares them lexicographically (in dictionary order). We compare the string based on the ASCII values and the program is Case sensitive. So the capital H is not the same as the lowercase h.
📢 This Program is part of the C String Practice Programs series
Here is the example input and output of the program.
Example Input and Output:
Input:
Enter the first string : CProgramming
Enter the second string : CProgramming
Output:
str1:CProgramming and str2:CProgramming are Equal
The Two input strings are equal.
Prerequisites:
Please go through the following articles to better understand this program.
- Strings in C Language – Declare, Initialize, and Modify Strings
- C Arrays
- Different ways to Read and Print strings in C
We are going to look at three methods to compare two strings in C Language in this article, They are
- Iterative Method: Manual comparison of strings using loops.
- User-Defined Function: Using a user-defined function(without strcmp) to compare the strings.
- strcat library function: Using the strcmp library function to compare the strings.
Compare Two Strings in C using Iterative Method ( Without strcmp function):
In C, To compare two strings, we can iterate through both strings character by character. If any differences are found, the strings are not equal. If we reach the end of the strings without finding any differences, the strings are considered equal.
Here is the step-by-step explanation of the String comparison program
An iterative method to Compare two strings in C Algorithm:
- Declare the two strings named str1 and str2 with SIZE size. ( i.e SIZE = 100 characters)
- Ask the user to input the strings for str1and str2and store the input in those variables.
- Now we need to compare the two strings. Create a for loop and start iterating through the two strings.
- FOR Loop – Start with i=0 and continue till str1[i] != '\0' && str2[i] != '\0'.
- At each iteration, Check if the str1[i] and str2[i] are not equal. If it is true, Then the two strings are Not Equal. break the loop. Otherwise, continue to the next iteration.
- Once the above loop is completed, Check if we reached the end of both strings (if(str1[i] == ‘\0’ && str2[i] == ‘\0’)), If so, Then we haven’t found any difference. So Given strings are Equal.
- Otherwise, Check if the (str1[i] < str2[i]), Then the str1 is lexicographically smaller than the str2
- If the above two cases are not satisfied, Then the str1 is lexicographically greater than the str2.
- Print the result on the console.
Program – String Comparision using Iterative Method:
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 |
/*     program to compare two strings in c     sillycodes.com */  #include<stdio.h>  const int SIZE = 100;  int main() {      // declare a string with 'SIZE'     char str1[SIZE], str2[SIZE];     int i;      // get the strings from the user     printf("Enter the first string : ");     scanf("%s", str1);         printf("Enter the second string : ");     scanf("%s", str2);         // Iterate over the two strings and compare elements     for(i=0; str1[i] != '\0' && str2[i] != '\0'; i++)     {         // Compare characters of 'str1' and 'str2'         if(str1[i] != str2[i])         {             // 'str1' and 'str2' are not equal             break;         }     }      // print the results     if(str1[i] == '\0' && str2[i] == '\0')     {         // both 'str1' and 'str2' are equal         printf("str1:%s and str2:%s are Equal\n", str1, str2);     }     else if (str1[i] < str2[i])     {         printf("str1:%s is lexicographically smaller than the str2:%s\n", str1, str2);     }     else     {         printf("str1:%s is lexicographically greater than the str2:%s\n", str1, str2);     }         return 0; } |
Program Output:
Let’s Compile and Run the Program.
Test case 1: When both strings are equal
1 2 3 4 5 6 |
$ gcc compare-strings.c $ ./a.out Enter the first string : CProgramming Enter the second string : CProgramming str1:CProgramming and str2:CProgramming are Equal $ |
The str1 and str2 are equal.
Test case 2: When the str1 is greater than str2
1 2 3 4 5 |
$ ./a.out Enter the first string : Hi Enter the second string : Hello str1:Hi is lexicographically greater than the str2:Hello $ |
First string Hi is lexicographically greater than the second string hello. Which means the first string Hi comes after the second string in the dictionary order.
Test case 3: When the str1 is smaller than str2
1 2 3 4 5 |
$ ./a.out Enter the first string : Rafa Enter the second string : Roger str1:Rafa is lexicographically smaller than the str2:Roger $ |
The First string( str1) Rafa is lexicographically smaller than the second string( str2) Roger. Which means the first string Rafa comes before the second string Roger in the dictionary order.
Program to Compare Two Strings using a User defined function in C Language:
Let’s look at the second method, To compare the Two string using a User defined Function (without the strcmp function).
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 59 60 61 62 63 |
/*     program to compare two strings in c using user defined function     sillycodes.com */  #include<stdio.h> const int SIZE = 100; // Function declaration int mystrcmp(char * str1, char * str2);  int main() {      // declare a string with 'SIZE'     char str1[SIZE], str2[SIZE];     int i;      // get the strings from the user     printf("Enter the first string : ");     scanf("%s", str1);         printf("Enter the second string : ");     scanf("%s", str2);         // Call the user defined 'mystrcmp' function with 'str1' and 'str2'     int result = mystrcmp(str1, str2);      // print the results     if(result == 0)     {         // both 'str1' and 'str2' are equal         printf("str1:%s and str2:%s are Equal\n", str1, str2);     }     else if (result < 0)     {         printf("str1:%s is lexicographically smaller than the str2:%s\n", str1, str2);     }     else     {         printf("str1:%s is lexicographically greater than the str2:%s\n", str1, str2);     }         return 0; }  int mystrcmp(char * str1, char * str2) {     int i;         // Iterate over the two strings and compare elements     for(i=0; str1[i] != '\0' && str2[i] != '\0'; i++)     {         // Compare characters of 'str1' and 'str2'         if(str1[i] != str2[i])         {             // 'str1' and 'str2' are not equal             break;         }     }      // Return the result - i.e ASCII value difference of the characters     return str1[i] - str2[i]; } |
We have defined a function mystrcmp in the above program to compare two strings. Prototype of the mystrcmp is int mystrcmp(char * str1, char * str2).
The mystrcmp() function takes two character pointers. Pointing to the str1 and str2 strings respectively. This function compares two strings by iterating over the all characters of the strings and returns the ASCII difference between the first non-matching character ( str1[i] - str2[i])
This mystrcmp function also returns similar results to the strcmp library function.
- a Zero(0) if the two strings are equal
- a Negative value if the str1 is smaller than the str2.
- a Positive Value if the str1 is greater than the str2.
Program Output:
Compile and run the program using GCC compiler (Any compiler)
1 2 3 4 5 6 |
$ gcc compare-strings.c $ ./a.out Enter the first string : Graham Enter the second string : Graham str1:Graham and str2:Graham are Equal $ |
The program is properly generating the results.
Compare two strings in C using the strcmp function:
The C Standard library provides the strcmp function to compare two strings. We already discussed the strcmp function in detailed in the following article.
Here is the syntax of the strcmp function.
1 |
int strcmp(const char * str1, const char * str2); |
Let’s use the in built strcmp function to compare the given strings.
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 |
/*     program to compare two strings in c using strcmp function     sillycodes.com */  #include<stdio.h> #include<string.h>          // for 'strcmp' function  const int SIZE = 100;  int main() {      // declare a string with 'SIZE'     char str1[SIZE], str2[SIZE];     int i;      // get the strings from the user     printf("Enter the first string : ");     scanf("%s", str1);         printf("Enter the second string : ");     scanf("%s", str2);         // Call 'strcmp' library function     int result = strcmp(str1, str2);      // print the results     if(result == 0)     {         // both 'str1' and 'str2' are equal         printf("str1:%s and str2:%s are Equal\n", str1, str2);     }     else if (result < 0)     {         printf("str1:%s is lexicographically smaller than the str2:%s\n", str1, str2);     }     else     {         printf("str1:%s is lexicographically greater than the str2:%s\n", str1, str2);     }         return 0; } |
Program Output:
Compile and Run the program.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
$ gcc compare-strings.c $ ./a.out Enter the first string : Queen Enter the second string : Queen str1:Queen and str2:Queen are Equal $ ./a.out Enter the first string : George Enter the second string : Russel str1:George is lexicographically smaller than the str2:Russel $ ./a.out Enter the first string : BBCC Enter the second string : AACC str1:BBCC is lexicographically greater than the str2:AACC $ |
As expected, The program is providing the desired results.
1 Response
[…] C Program to Compare Two Strings […]