Skip to content

Blind 75

Arrays

Two Sum

//Use a HashMap to store numbers and their indices.
//For each number in the array, compute its complement to reach the target
//Check if the complement is in the HashMap
//If yes, return the current index and the index of the complement
//If no, add the number and its index to the HashMap
    if (nums == null || nums.length < 2) {
    throw new IllegalArgumentException("Invalid input array");
    }
    HashMap<Integer, Integer> map = new HashMap<>();
    int[] result = new int[2];
    for (int i = 0; i < nums.length; i++) {
    int complement = target - nums[i];
    if (map.containsKey(complement)) {
    result[0] = i;
    result[1] = map.get(complement);
    return result;
    }
    map.put(nums[i], i);
    }
Summary

To find two numbers in an array that add up to a target, use a HashMap for quick lookups. As you iterate through the array, calculate the complement needed to reach the target for each number. Check if this complement is already in the HashMap. If it is, return the indices of the current number and the complement. If not, store the current number and its index in the HashMap for future reference. This method allows you to find the solution efficiently in one pass through the array.

Best Time to Buy and Sell Stock

//Track the lowest price while iterating through the prices.
//Calculate the profit by subtracting the tracked minimum price from each current price.
        int minprice = Integer.MAX_VALUE;
        int maxprofit = 0;
        for (int i = 0; i < prices.length; i++) {
            if (prices[i] < minprice) {
                minprice = prices[i];
            } else if (prices[i] - minprice > maxprofit) {
                maxprofit = prices[i] - minprice;
            }
        }
        return maxprofit;
Summary

The new number is lower than the lowest point found so far, so you update it. The new number is higher than your low point so it is a possible solution and you calculate the difference to find the profit. If it's higher than your max profit found so far, update. YouTube Resource

Contains Duplicate

//Create a HashSet to store seen integers.
//Loop through each integer in the array.
//Try to add each integer to the HashSet.
//If adding the integer returns false, return true (found a duplicate).
//If the loop completes without finding duplicates, return false.
    public boolean containsDuplicate(int[] nums) {
    Set<Integer> set = new HashSet<Integer>();
    for (int num : nums) {
        if (set.contains(num)) {
            return true;
        }
        set.add(num);
    }
    return false;
    }

Product of Array Except Self

//Create prefixProducts, suffixProducts, and resultArray arrays.
//Set prefixProducts[0] to 1 and suffixProducts[length-1] to 1.
//Iterate from left to right, storing cumulative products in prefixProducts.
//Iterate from right to left, storing cumulative products in suffixProducts.
//Multiply corresponding elements of prefixProducts and suffixProducts to fill resultArray.
//Return the final resultArray.
    int length = nums.length;
    int[] prefixProducts = new int[length];
    prefixProducts[0] = 1;
    int[] suffixProducts = new int[length];
    suffixProducts[length - 1] = 1;
    int[] resultArray = new int[length];

    for (int i = 1; i < length; i++) {
        prefixProducts[i] = nums[i - 1] * prefixProducts[i - 1];  
    }

    for (int i = length - 2; i >= 0; i--) {
        suffixProducts[i] = nums[i + 1] * suffixProducts[i + 1];
    }

    for (int i = 0; i < length; i++) {
        resultArray[i] = prefixProducts[i] * suffixProducts[i];   
    }

    return resultArray;

Maximum Subarray

//Initialize Variables: Set maxSum to Integer.MIN_VALUE and currSum to 0.
//Iterate Through the Array: Add each element to currSum.
//Update maxSum: Set maxSum to the greater of maxSum and currSum.
//Reset currSum if Negative: If currSum is less than 0, reset it to 0.
//Return maxSum: After the loop, return maxSum.
    int maxSum = Integer.MIN_VALUE;
    int currSum = 0;
    for(int i=0; i<nums.length; i++) {
        currSum += nums[i];
        maxSum = Math.max(maxSum, currSum);
        if (currSum < 0) {
            currSum = 0;
        }
    } return maxSum;

Maximum Product Subarray

//Initialization: Create prefix and suffix variables, initialize both to 1, and initialize result to 0.
//Iteration: Loop through the array from 0 to n-1.
//Reset Prefix and Suffix: If prefix or suffix is 0, reset it to 1.
//Update Prefix and Suffix: Multiply prefix by nums[i] and suffix by nums[n-i-1].
//Update Result: Use Math.max to set result to the maximum of result, prefix, and suffix.
//Return Result: Cast result to int and return it.
int n= nums.length;
double prefix = 1;
double suffix = 1;
double result = 0;
if(n == 1) return nums[0];
for (int i=0; i<n; i++) {
    if (prefix == 0) { prefix = 1;}
    if (suffix == 0) { suffix = 1;}
    prefix *= nums[i];
    suffix *= nums[n-i-1];
    result = Math.max(result, Math.max(prefix, suffix)); 
}
return (int) result;

Find Minimum in Rotated Sorted Array

//Initialize Pointers: Set up left and right to cover the entire array.
//Binary Search Loop: Narrow down the search range by repeatedly halving it.
//Midpoint Calculation: Calculate the midpoint and compare it to the element at right to decide which half to search next.
//Adjust Pointers: Move left or right based on the comparison to narrow the search range.
//Return Result: When the loop ends, left points to the minimum value.
    int left = 0;
    int right = nums.length-1;
    while (left<right) {
        int mid = (left+right)/2;
        if (nums[mid] > nums[right]) {
            left = mid + 1; 
        } else {
            right = mid;
        }
    } return nums[left];
Summary

The midpoint calculation int mid = left + (right - left) / 2 is used in binary search to avoid potential integer overflow and ensure accurate results. When left and right are large, directly using (left + right) / 2 could lead to overflow, as their sum might exceed the maximum integer value. By calculating mid as left + (right - left) / 2, the difference right - left is smaller and less prone to overflow, and dividing by 2 ensures the result is within a safe range. Adding left then adjusts the midpoint correctly within the current search segment, ensuring precise calculations without risking overflow.