. Day 8 - Challenge 3 - Unique Email Addresses Skip to main content

Day 8 - Challenge 3 - Unique Email Addresses

Solving the Problem of Counting Unique Email Addresses in JavaScript

Introduction: 

In today's digital age, email communication is an integral part of our lives. However, dealing with unique email addresses can sometimes be challenging due to variations that arise from period usage and the '+' character. In this blog post, we will explore how to tackle the problem of counting unique email addresses using JavaScript.

Problem Statement: We are given a list of email addresses, and our task is to determine the number of unique email addresses. A unique email address consists of a local name and a domain name. The local name may contain periods ('.') and the character '+' which is ignored.

Example: 

Let's consider the following list of email addresses:

  • "test.email+abc@gmail.com"
  • "test.e.mail@gmail.com"
  • "testemail@gmail.com"

In this case, the number of unique email addresses is 1, as all three email addresses map to the same unique address: "testemail@gmail.com".

Approach and Solution: 

To solve this problem, we need to apply the following steps using JavaScript:

  1. Iterate through each email address in the list.
  2. For each email address, split it into the local name and domain name using the '@' symbol.
  3. Process the local name:
    • Remove all '.' characters from the local name.
    • Ignore all characters after the '+' character.
  4. Concatenate the modified local name with the domain name to form the unique email address.
  5. Use a Set data structure to keep track of unique email addresses.
  6. Count the number of elements in the Set, which will give us the final count of unique email addresses.

JavaScript Code Implementation:

function countUniqueEmails(emails) {
    const uniqueEmails = new Set();
    for (const email of emails) {
        const [local, domain] = email.split('@');
        const modifiedLocal = local.replace(/\./g, '').split('+')[0];
        const uniqueEmail = `${modifiedLocal}@${domain}`;
        uniqueEmails.add(uniqueEmail);
    }
    return uniqueEmails.size;
}
// Example usage
const emailList = [
    "test.email+abc@gmail.com",
    "test.e.mail@gmail.com",
    "testemail@gmail.com"
];
const uniqueCount = countUniqueEmails(emailList);
console.log("Number of unique email addresses:", uniqueCount); // Output: 1

Conclusion: 

In this blog post, we addressed the challenge of counting unique email addresses that arise from variations in the local name due to periods and the '+' character. By following a step-by-step approach and implementing the solution using JavaScript, we were able to accurately determine the number of unique email addresses in a given list. This solution showcases the power of JavaScript in solving real-world problems efficiently.

Now write the same program in your favorite language in comment section. 

Other Challenges:

  1. Day 6 Challenges 
  2. Day 7 Challenges
  3. Day 8 Challenges

Comments

Popular posts from this blog

Connecting to Socket in React Native app

Connecting to a socket in a React Native app requires the use of a socket library that supports React Native. One popular library is socket.io-client . Here are the steps to connect to a socket using socket.io-client in a React Native app: Install socket.io-client by running the following command in your project directory: npm install socket.io-client 2. Import the library in your code: import io from 'socket.io-client'; 3. Create a socket instance by calling the io function and passing in the URL of the socket server: const socket = io('http://example.com'); Replace http://example.com with the URL of your socket server. 4. Add event listeners to the socket instance to handle incoming events: socket.on('connect', () => { console.log('Connected to socket server'); }); socket.on('event', (data) => { console.log('Received data:', data); }); Replace event with the name ...

Create app in phonegap in windows

Phonegap (Cordova) is a tool that allows creating native mobile app using HTML, CSS and Javascript. This article shows you, how to create application and deploy them to various native mobile platforms using the cordova command-line interface (CLI). Install Cordova using CLI Follow these steps to install: Download and install Node.js . Following installation, you should be able to invoke node and npm on your command line. Install the cordova module using npm utility of Node.js. The cordova module will automatically be downloaded by the npm utility.   $ npm install -g cordova Create APP: Go to the directory where you maintain your source code, and run a command such as the following: using command. Create hello app: $ cordova create hello com.example.hello HelloWorld This command will create a folder ‘HelloWorld’. All subsequent commands need to be run within the project's directory, or any subdirectories. So go to in this folder ‘cd HelloWorld’. Add the pl...

Know about the Web Socket and setup WebSocket in Javascript HTML page

  WebSockets is a protocol for providing full-duplex communication channels over a single TCP connection. It allows for real-time, two-way communication between a client and a server, which makes it ideal for web applications that require continuous updates from the server or that need to send frequent updates to the server. Here are some basic information about WebSockets: WebSockets are designed to work over a single TCP connection, which means that they are more efficient than other protocols like HTTP that require multiple connections for each request/response cycle. WebSockets use a persistent connection between the client and server, which allows for real-time communication without the need for frequent polling or long-polling requests. The WebSocket protocol uses a message-based model for sending and receiving data, which means that data is transmitted as a stream of messages rather than a series of HTTP requests and responses. WebSockets support binary data transmission, wh...