. Day 5 - Challenge 1 - Two Sum Skip to main content

Day 5 - Challenge 1 - Two Sum

Solving the Two Sum Problem in JavaScript

The Two Sum problem is a classic coding challenge that involves finding two numbers in an array that add up to a given target sum. In this blog post, we'll walk through the problem-solving process step by step and implement a solution in JavaScript.

Problem Statement

Given an array of integers and a target sum, our task is to find two distinct numbers from the array that add up to the target sum. We need to return the indices of these two numbers in the array.

For example, if the input array is [2, 7, 11, 15] and the target sum is 9, the output should be [0, 1] because 2 + 7 = 9.

Approach

To solve this problem efficiently, we can use a hash map to store the numbers we have encountered so far along with their indices. As we iterate through the array, we can check if the difference between the current number and the target sum exists in the hash map. If it does, then we've found our solution.

Here's the step-by-step approach:

  1. Create an empty hash map to store numbers and their indices.
  2. Iterate through the array.
  3. For each number num at index i, calculate the complement as target - num.
  4. Check if the complement exists in the hash map.
    • If it does, return the indices [hashMap[complement], i].
    • If not, add the current number and its index to the hash map.

Implementation

Let's implement the solution in JavaScript:


function twoSum(nums, target) {
    const hashMap = {};

    for (let i = 0; i < nums.length; i++) {
        const num = nums[i];
        const complement = target - num;

        if (hashMap.hasOwnProperty(complement)) {
            return [hashMap[complement], i];
        }

        hashMap[num] = i;
    }

    return null; // If no solution is found
}

// Example usage
const nums = [2, 7, 11, 15];
const target = 9;
const result = twoSum(nums, target);
console.log(result); // Output: [0, 1]

Demo

Two Sum Problem Solver


Conclusion

The Two Sum problem is a common coding challenge that tests your problem-solving skills and knowledge of hash maps. By using a hash map to keep track of encountered numbers and their indices, we can efficiently solve this problem in linear time complexity.

Remember to analyze the time and space complexity of your solution. In this case, the time complexity is O(n), where n is the number of elements in the array, and the space complexity is O(n) as well due to the hash map.

I hope this blog post helps you understand how to approach and solve the Two Sum problem using JavaScript. Happy coding!

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

Other Challenges:

  1. Day 2 Challenges
  2. Day 3 Challenges
  3. Day 4 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...