Friday, 28 January 2022

Leet Code Practice Solutions with Explanations

Practice with me- I try to code here and put up my solutions, let me know if you find a better solution than me



238. Product of Array Except Self
Medium

Given an integer array nums, return an array answer such that answer[i] is equal to the product of all the elements of nums except nums[i].

The product of any prefix or suffix of nums is guaranteed to fit in a 32-bit integer.

You must write an algorithm that runs in O(n) time and without using the division operation.

 

Example 1:

Input: nums = [1,2,3,4]
Output: [24,12,8,6]

Example 2:

Input: nums = [-1,1,0,-3,3]
Output: [0,0,9,0,0]

 

Constraints:

  • 2 <= nums.length <= 105
  • -30 <= nums[i] <= 30
  • The product of any prefix or suffix of nums is guaranteed to fit in a 32-bit integer.

 

Follow up: Can you solve the problem in O(1) extra space complexity? (The output array does not count as extra space for space complexity analysis.)


class Solution {
    public int[] productExceptSelf(int[] nums) {
        
        int arr [] = new int[nums.length];
        int prod = 1;
        int zerocount = 0;
        for(int i=0;i<nums.length;i++)
        {
            if(nums[i]!=0)
            {
                prod = prod*nums[i];
            }
            else
            {
                zerocount = zerocount+1;
            }
            
        }
        if(zerocount>=2)
        {
            return arr;
        }
        
        for(int i=0;i<nums.length;i++)
        {
            if(nums[i]==0)
            {
                arr [i] = prod;
            }
            else if(nums[i]!=0 && zerocount == 1)
            {
                arr[i] = 0;
            }
            else
            {
                 arr [i] = prod/nums[i];
            }
           
        }
        
        return arr;
        
    }
}
123. Best Time to Buy and Sell Stock III
Hard

You are given an array prices where prices[i] is the price of a given stock on the ith day.

Find the maximum profit you can achieve. You may complete at most two transactions.

Note: You may not engage in multiple transactions simultaneously (i.e., you must sell the stock before you buy again).

 

Example 1:

Input: prices = [3,3,5,0,0,3,1,4]
Output: 6
Explanation: Buy on day 4 (price = 0) and sell on day 6 (price = 3), profit = 3-0 = 3.
Then buy on day 7 (price = 1) and sell on day 8 (price = 4), profit = 4-1 = 3.

Example 2:

Input: prices = [1,2,3,4,5]
Output: 4
Explanation: Buy on day 1 (price = 1) and sell on day 5 (price = 5), profit = 5-1 = 4.
Note that you cannot buy on day 1, buy on day 2 and sell them later, as you are engaging multiple transactions at the same time. You must sell before buying again.

Example 3:

Input: prices = [7,6,4,3,1]
Output: 0
Explanation: In this case, no transaction is done, i.e. max profit = 0.

 

Constraints:

  • 1 <= prices.length <= 105
  • 0 <= prices[i] <= 105


 class Solution {

    public int maxProfit(int[] prices) {

        

        

        int sum =0;

        int p1 = -prices[0];

        int p2 = Integer.MIN_VALUE;;

        int p3 = Integer.MIN_VALUE;

        int p4 = Integer.MIN_VALUE;

        

        for(int i=0;i<prices.length;i++)

        {

            p1 = Math.max(p1,-prices[i]); //finding on first txn the lowest trade value

            p2 = Math.max(p2,p1+prices[i]); //selling for max profit 

            p3 = Math.max(p3,p2-prices[i]); //adding first txn profit and reducing with lowest selling price for day 2 txn  

            p4 = Math.max(p4,p3+prices[i]); //selling the second txn for max profit


        }

        return Math.max(0,p4);

        

    }

}

122. Best Time to Buy and Sell Stock II
Medium

You are given an integer array prices where prices[i] is the price of a given stock on the ith day.

On each day, you may decide to buy and/or sell the stock. You can only hold at most one share of the stock at any time. However, you can buy it then immediately sell it on the same day.

Find and return the maximum profit you can achieve.


Example 1:

Input: prices = [7,1,5,3,6,4]
Output: 7
Explanation: Buy on day 2 (price = 1) and sell on day 3 (price = 5), profit = 5-1 = 4.
Then buy on day 4 (price = 3) and sell on day 5 (price = 6), profit = 6-3 = 3.
Total profit is 4 + 3 = 7.

Example 2:

Input: prices = [1,2,3,4,5]
Output: 4
Explanation: Buy on day 1 (price = 1) and sell on day 5 (price = 5), profit = 5-1 = 4.
Total profit is 4.

Example 3:

Input: prices = [7,6,4,3,1]
Output: 0
Explanation: There is no way to make a positive profit, so we never buy the stock to achieve the maximum profit of 0.

 

Constraints:

  • 1 <= prices.length <= 3 * 104
  • 0 <= prices[i] <= 104

public class solution3 {
public static void main(String[] args) {

secondQuestion(new int[]{7,1,5,3,6,4});
}
public static void secondQuestion(int []prices)
{
int sum = 0;
for(int i=0;i<prices.length-1;i++)
{
if(prices[i]<prices[i+1])
{
sum = sum+(prices[i+1]-prices[i]); //adding the total profit gained per day
}
}
System.out.println(sum);
}
}


121. Best Time to Buy and Sell Stock
Easy

You are given an array prices where prices[i] is the price of a given stock on the ith day.

You want to maximize your profit by choosing a single day to buy one stock and choosing a different day in the future to sell that stock.

Return the maximum profit you can achieve from this transaction. If you cannot achieve any profit, return 0.

 

Example 1:

Input: prices = [7,1,5,3,6,4]
Output: 5
Explanation: Buy on day 2 (price = 1) and sell on day 5 (price = 6), profit = 6-1 = 5.
Note that buying on day 2 and selling on day 1 is not allowed because you must buy before you sell.

Example 2:

Input: prices = [7,6,4,3,1]
Output: 0
Explanation: In this case, no transactions are done and the max profit = 0.

 

Constraints:

  • 1 <= prices.length <= 105
  • 0 <= prices[i] <= 104


SOLUTION - 

public class solution3 {
public static void main(String[] args) {
maxProfit(new int[]{7,1,5,3,6,4}); //this solution is by using brute force
maxpr(new int[]{7,1,5,3,6,4}); //this is dynamic programming solution

}

public static void maxProfit(int[] prices) {
int max = 0;
for(int i=0;i<prices.length;i++)
{
for(int j=i+1;j<prices.length;j++)
{
if(prices[i]<prices[j])
{
if(prices[j]-prices[i]>max)
{
max = prices[j]-prices[i];
}

}

}
}
System.out.println("max is "+max);
}

public static void maxpr(int []prices)
{
int lsp = Integer.MAX_VALUE; //a randomly high value -> it will contain the least selling price(lsp)
int maxprofit = 0; //this contains maximum profit which can be earned going chronologically
for(int i=0;i<prices.length;i++)
{
if(prices[i]<lsp)
{
lsp = prices[i]; //update the least selling price
}
if(maxprofit<prices[i]-lsp) //calculate profit
{
maxprofit = prices[i]-lsp; //update if profit is max
}
}
System.out.println(maxprofit);
}
}


5. Longest Palindromic Substring
Medium

Given a string s, return the longest palindromic substring in s.

 

Example 1:

Input: s = "babad"
Output: "bab"
Explanation: "aba" is also a valid answer.

Example 2:

Input: s = "cbbd"
Output: "bb"

 

Constraints:

  • 1 <= s.length <= 1000
  • s consist of only digits and English letters.

SOLUTION - 


public class solution2 {
public static void main(String[] args) {
System.out.println(longestpalindrome("cbbd"));
}

public static String longestpalindrome(String str)
{
int l = str.length();
if(l==1)
{
return str;
}
int arr[][] = new int[l][l];
for(int i=0;i<l;i++)
{
arr[i][i] = 1;
}
System.out.println("lem is"+l);

int max=0,r1=0,r2=0;

//for 2 digit pairs
for(int i=0;i<l;i++)
{
int j=i+1;
if(j<l && str.charAt(i)==str.charAt(j))
{
arr[i][j] = 1;
if(j>max)
{
max = j;
r1 = j;
r2 = i;
}
if(i>max)
{
max = i;
r1 = j;
r2 = i;
}
}

}

//for 3+ digit pairs

for(int i=3;i<=l;i++)
{
for(int j=0;j<l;j++)
{
//next index
int k = j+i-1;
if(k<l && str.charAt(j) == str.charAt(k) && arr[j+1][k-1]==1 )
{
arr[j][k] = 1;
if(j>max)
{
max = j;
r1 = i;
r2 = j;
}
if(k>max)
{
max = k;
r1 = i;
r2 = j;
}
}
}
}



//printing
for(int i=0;i<l;i++)
{
for(int j=0;j<l;j++)
{
System.out.print(arr[i][j]);
}
System.out.println();
}

System.out.println("r1:"+r1+" r2:"+r2);
return(str.substring(r2,r1+r2));

}
}


Source - Leetcode

119. Pascal's Triangle II
Easy

Given an integer rowIndex, return the rowIndexth (0-indexed) row of the Pascal's triangle.

In Pascal's triangle, each number is the sum of the two numbers directly above it as shown:

 

Example 1:

Input: rowIndex = 3
Output: [1,3,3,1]

Example 2:

Input: rowIndex = 0
Output: [1]

Example 3:

Input: rowIndex = 1
Output: [1,1]

 

Constraints:

  • 0 <= rowIndex <= 33

Solution - 

MY SOLUTION - 

class Solution {
    public List<Integer> getRow(int rowIndex) {
        
        int i =1 ;
        ArrayList<Integer> list = new ArrayList<Integer>();
        list.add(1);
        list.add(1);
        
        while(rowIndex!=i) {

            list = generatetraingle(list);
            //System.out.println(list);
            i=i+1;

        }
        return list;
        
    }
    
    public static ArrayList<Integer> generatetraingle(ArrayList<Integer> list)
    {
        list.add(0,0);
        list.add(list.size(),0);
        //System.out.println(list);
        ArrayList<Integer> list2 = new ArrayList<Integer>();
        for(int i=0;i<list.size()-1;i++)
        {
            list2.add(i, list.get(i)+list.get(i+1));
        }
        //System.out.println(list2);
        return list2;
    }
}

ACCEPTABLE SOLUTION -

import java.util.ArrayList;
import java.util.List;

public class solution {

public static void main(String[] args)
{
System.out.println(mysol(10));
}



public static List<Integer> mysol(int rowIndex)
{
ArrayList<Integer> arr = new ArrayList<Integer>(rowIndex+1);
for(int i=0;i<rowIndex+1;i++)
{
arr.add(0);
for(int j=i;j>=0;j--)
{
if(j==0 || j==i)
{
arr.set(j,1);
System.out.println("IF"+arr);
}
else
{
arr.set(j, arr.get(j-1) + arr.get(j));
System.out.println("ELSE"+arr);
}
}

}
return arr;
}
}


Question-

Distinct Subsequences

Medium
Asked In:
GOOGLE

Given two sequences A, B, count number of unique ways in sequence A, to form a subsequence that is identical to the sequence B.

Subsequence : A subsequence of a string is a new string which is formed from the original string by deleting some (can be none) of the characters without disturbing the relative positions of the remaining characters. (ie, “ACE” is a subsequence of “ABCDE” while “AEC” is not).

Input Format:

The first argument of input contains a string, A.
The second argument of input contains a string, B.

Output Format:

Return an integer representing the answer as described in the problem statement.

Constraints:

1 <= length(A), length(B) <= 700

Example :

Input 1:
    A = "abc"
    B = "abc"
    
Output 1:
    1

Explanation 1:
    Both the strings are equal.

Input 2:
    A = "rabbbit" 
    B = "rabbit"

Output 2:
    3

Explanation 2:
    These are the possible removals of characters:
        => A = "ra_bbit" 
        => A = "rab_bit" 
        => A = "rabb_it"
        
    Note: "_" marks the removed character.

SOLUTION - 

public class handler {

public static void main(String args[]) {

// Your code goes here

//System.out.println("out is "+ numDistinct("aaaababbababbaabbaaababaaabbbaaabbb","bbababa"));

System.out.println("out is "+ numDistinct("babbab","bab"));

}





public static int numDistinct(String a, String b) {

        int m = b.length();

        int n = a.length();

        if(m>n){

            return 0;

        }

        int dp[][] = new int[m+1][n+1];

        for(int i=1;i<=m;i++)

{

//setting first cloumn zero

            dp[i][0]=0;

        }

        for(int i=0;i<=n;i++)

{

//setting first row 1

            dp[0][i]=1;

        }

        for(int i=1;i<=m;i++){

            for(int j=1;j<=n;j++){

                if(b.charAt(i-1)!=a.charAt(j-1)){

                    dp[i][j] = dp[i][j-1];

                }

                else{

                    dp[i][j] = dp[i][j-1]+dp[i-1][j-1];

                }

            }

     //printing matrix   

        for(int i=0;i<=m;i++){

            for(int j=0;j<=n;j++){

                System.out.print(dp[i][j]+" ");

            }

            System.out.println();

        }

        return dp[m][n];

    }

}



Question -

Majority Element

Easy

Problem Description

Given an array of size n, find the majority element. The majority element is the element that appears more than floor(n/2) times.

You may assume that the array is non-empty and the majority element always exist in the array.

Example :

Input : [2, 1, 2]
Return  : 2 which occurs 2 times which is greater than 3/2.


question source - interviewbit.com


MY SOLUTION -

public class Solution {
    // DO NOT MODIFY THE ARGUMENTS WITH "final" PREFIX. IT IS READ ONLY
    public int majorityElement(final int[] A) {

        Arrays.sort(A);
        int num=0,count=0,max=0,memory=0;
        for(int i=0;i<A.length;i++)
        {
            if(A.length==1)
            {
                return A[0];
            }
            if(i==0)
            {
                num = A[0];
                count = 1;
            }
            else
            {
                if(num == A[i])
                {
                    count=count+1;
                    if(max<count)
                    {
                        max = count;
                        memory = A[i];
                    }
                }
                else
                {
                    num = A[i];
                    count = 1;
                }
            }
        }
        return memory;

    }
}



Explanation -  The question basically tells you to measure the maximum number of elements in an array, the best way to solve the problem in O(n) is to sort the array(use inbuilt functions by Arrays.sort ) and then keep the maximum number obtained yet in a variable, don't be afraid of creating a lot of variables, I don't think anyone will care about a number of variables used, rather interviewers check the approach and time complexity.

GPT4ALL - A new LLaMa (Large Language Model)

posted 29th March, 2023 - 11:50, GPT4ALL launched 1 hr ago  What if we use AI generated prompt and response to train another AI - Exactly th...