/ #algorithms 

Count Characters Algorithm

Solution to counting the number of characters in a given string that are at the same position on the English alphabet. C#

Problem

Given a string count he number of characters that are at the same position on the English alphabet.

Check the complete project on my Github

Example

Input:

"ABCde"

Output:

3

Solution

namespace CountCharacters
{
    class Program
    {       
        public static int FindCount(string str)
        {
            var result = 0;

            for (var i = 0; i <= 26; i++)
            {
                //Check if the result of sustracting the ASCII value of the letter in the position [i] of the array and the ASCII
                //value of a or A is equal to the value of i. Increment the counter (result) if one of the operations is true.
                
                if (i == (str[i] - 'a') || (i == str[i] - 'A'))
                {
                    result++;
                    
                    //Print to the console the characters and their position in the string.
                    Console.Write("Character: " + str[i] + " at position: " + i + "\n");
                }                                      
            }
            //Return the total number of found characters
            return result;
        }
        static void Main(string[] args)
        {
            const string str = "ABCed";
            Console.Write("Total number of matching characters: " + FindCount(str));
            Console.ReadLine();
        }
    }
}

Solution using XOR operations

namespace CountCharacters
{
    class Program
    {       
        public static int FindCount(string str)
        {
            var result = 0;

            for (var i = 0; i <= 26; i++)
            {
                //Check if the result of sustracting the ASCII value of the letter in the position [i] of the array and the ASCII
                //value of a or A is equal to 0 when XOR'd with the value of i. Increment the counter (result) if one of the operations is true. 
                
                if ((i ^ str[i] - 'a') == 0 || (i ^ str[i] - 'A') == 0)
                {
                    result++;
                    
                    //Print to the console the characters and their position in the string.
                    Console.Write("Character: " + str[i] + " at position: " + i + "\n");
                }                                      
            }
            //Return the total number of found characters
            return result;
        }
        static void Main(string[] args)
        {
            const string str = "ABCed";
            Console.Write("Total number of matching characters: " + FindCount(str));
            Console.ReadLine();
        }
    }
}

XOR operations:

0 ^ 0 = 0
0 ^ 1 = 1
1 ^ 0 = 1
1 ^ 1 = 1

Other XOR rules:

a ^ a = 0
0 ^ a = a
Author

Abraham Laria

Sr. Software Engineer at Pinnacle Entertainment Inc. Aspiring Solution Architect, interested in Team Management.