Similar Problems

Similar Problems not available

Minimum Operations To Make A Subsequence - Leetcode Solution

Companies:

LeetCode:  Minimum Operations To Make A Subsequence Leetcode Solution

Difficulty: Hard

Topics: greedy hash-table binary-search array  

Problem Statement:

Given two integer arrays nums1 and nums2, return the length of the longest subsequence that appears in both arrays.

A subsequence is a sequence that can be derived from another sequence by deleting some or no elements without changing the order of the remaining elements.

Constraints: 1 <= nums1.length, nums2.length <= 1000 0 <= nums1[i], nums2[i] <= 2000

Example:

Input: nums1 = [1,3,5,6,7], nums2 = [1,2,3,4,5,6]

Output: 4

Explanation:

The longest subsequence is [1,3,5,6] or [1,2,3,6] or [1,2,3,4,5,6], all of which have a length of 4.

Solution:

The given problem can be solved using dynamic programming. The subproblem can be defined as follows: Let dp[i][j] denote the length of the longest common subsequence that can be formed from the given two arrays up to the i-th element of nums1 and the j-th element of nums2.

The base cases are dp[0][j] = 0 and dp[i][0] = 0, as there cannot be any common subsequence between an empty array and any other array.

If nums1[i] == nums2[j], then dp[i][j] = 1 + dp[i-1][j-1], as the current element can be added to the longest common subsequence formed till the i-1th element of nums1 and j-1th element of nums2.

Otherwise, dp[i][j] = max(dp[i-1][j], dp[i][j-1]), as there can be two possibilities to form the longest common subsequence i.e., either by removing the i-th element of nums1 or by removing the j-th element of nums2.

At the end, dp[nums1.length][nums2.length] will give the length of the longest common subsequence that can be formed from the given two arrays.

Implementation:

public int minOperations(int[] nums1, int[] nums2) {

int n1 = nums1.length;
int n2 = nums2.length;

if (n1 * 6 < n2 || n2 * 6 < n1) {
    return -1;
}

int[] freq1 = new int[7];
int[] freq2 = new int[7];

int diff = 0;

for (int num : nums1) {
    freq1[num]++;
    diff += num;
}

for (int num : nums2) {
    freq2[num]++;
    diff -= num;
}

if (diff > 0) {
    freq1 = freq2;
    freq2 = freq1;
    diff = -diff;
}

int count = 0;

for (int i = 1; i <= 6; i++) {
    int j = 7 - i;
    while (freq1[i] > 0 && diff > 0 || freq2[j] > 0 && diff > 0) {
        if (freq1[i] > 0) {
            freq1[i]--;
            diff -= 6 - i;
        } else {
            freq2[j]--;
            diff -= j - 1;
        }
        count++;
    }
}

return count;

}

Minimum Operations To Make A Subsequence Solution Code

1int minimumOperations(vector<int>& nums) {
2        int n = nums.size();
3        int dp[n][3];
4        for(int i = 0; i < n; i++) {
5            if(i == 0) {
6                dp[i][0] = nums[i];
7                dp[i][1] = INT_MAX;
8                dp[i][2] = INT_MAX;
9            } else {
10                dp[i][0] = nums[i] + dp[i-1][0];
11                dp[i][1] = min(dp[i-1][0], dp[i-1][1]) + nums[i];
12                dp[i][2] = min(dp[i-1][1], dp[i-1][2]) + nums[i];
13            }
14        }
15        return dp[n-1][2];
16    }