📌  相关文章
📜  通过替换由相等元素组成的最小子序列,使所有数组元素等于0

📅  最后修改于: 2021-05-06 18:51:28             🧑  作者: Mango

给定大小为N的数组arr [] ,任务是通过将相等元素子序列的所有元素替换为任意整数(最小次数)来使所有数组元素等于0

例子:

方法:可以使用贪婪技术解决问题。想法是对不等于0的数组中存在的不同元素进行计数,并打印获得的计数。请按照以下步骤解决问题:

  • 初始化一个Set来存储数组中存在的不等于0的不同元素。
  • 遍历数组arr []并将数组元素插入Set中。
  • 最后,打印集的大小。

下面是上述方法的实现:

C++
// C++ program for the above approach
 
#include 
using namespace std;
 
// Function to find minimum count of operations
// required to convert all array elements to zero
// br replacing subsequence of equal elements to 0
void minOpsToTurnArrToZero(int arr[], int N)
{
 
    // Store distinct elements
    // present in the array
    unordered_set st;
 
    // Traverse the array
    for (int i = 0; i < N; i++) {
 
        // If arr[i] is already present in
        // the Set or arr[i] is equal to 0
        if (st.find(arr[i]) != st.end()
            || arr[i] == 0) {
            continue;
        }
 
        // Otherwise, increment ans by
        // 1 and insert current element
        else {
            st.insert(arr[i]);
        }
    }
 
    cout << st.size() << endl;
}
 
// Driver Code
int main()
{
 
    // Given array
    int arr[] = { 3, 7, 3 };
 
    // Size of the given array
    int N = sizeof(arr) / sizeof(arr[0]);
 
    minOpsToTurnArrToZero(arr, N);
 
    return 0;
}


Java
// Java program for the above approach
import java.io.*;
import java.util.*;
 
class GFG {
 
    // Function to find minimum count of operations
    // required to convert all array elements to zero
    // br replacing subsequence of equal elements to 0
    static void minOpsToTurnArrToZero(int[] arr, int N)
    {
 
        // Store distinct elements
        // present in the array
        Set st = new HashSet();
        // Traverse the array
        for (int i = 0; i < N; i++) {
 
            // If arr[i] is already present in
            // the Set or arr[i] is equal to 0
            if (st.contains(arr[i]) || arr[i] == 0) {
                continue;
            }
 
            // Otherwise, increment ans by
            // 1 and insert current element
            else {
                st.add(arr[i]);
            }
        }
 
        System.out.println(st.size());
    }
 
    // Driver Code
    public static void main(String args[])
    {
        // Given array
        int arr[] = { 3, 7, 3 };
 
        // Size of the given array
        int N = arr.length;
 
        minOpsToTurnArrToZero(arr, N);
    }
}
 
// This code is contributed by 18bhupendrayadav18


Python3
# Python3 program for the above approach
 
# Function to find minimum count of
# operations required to convert all
# array elements to zero by replacing
# subsequence of equal elements to 0
def minOpsToTurnArrToZero(arr, N):
     
    # Store distinct elements
    # present in the array
    st = dict()
 
    # Traverse the array
    for i in range(N):
 
        # If arr[i] is already present in
        # the Set or arr[i] is equal to 0
        if (i in st.keys() or arr[i] == 0):
            continue
         
        # Otherwise, increment ans by
        # 1 and insert current element
        else:
            st[arr[i]] = 1
             
    print(len(st))
 
# Driver Code
 
# Given array
arr = [ 3, 7, 3 ]
 
# Size of the given array
N = len(arr)
 
minOpsToTurnArrToZero(arr, N)
 
# This code is contributed by susmitakundugoaldanga


C#
// C# program for the above approach
using System;
using System.Collections.Generic;
 
class GFG {
 
  // Function to find minimum count of operations
  // required to convert all array elements to zero
  // br replacing subsequence of equal elements to 0
  static void minOpsToTurnArrToZero(int[] arr, int N)
  {
 
    // Store distinct elements
    // present in the array
    HashSet st = new HashSet();
 
    // Traverse the array
    for (int i = 0; i < N; i++)
    {
 
      // If arr[i] is already present in
      // the Set or arr[i] is equal to 0
      if (st.Contains(arr[i]) || arr[i] == 0)
      {
        continue;
      }
 
      // Otherwise, increment ans by
      // 1 and insert current element
      else
      {
        st.Add(arr[i]);
      }
    }
    Console.WriteLine(st.Count);
  }
 
  // Driver Code
  public static void Main(String []args)
  {
 
    // Given array
    int []arr = { 3, 7, 3 };
 
    // Size of the given array
    int N = arr.Length;
    minOpsToTurnArrToZero(arr, N);
  }
}
 
// This code is contributed by gauravrajput1


输出:
2

时间复杂度: O(N)
辅助空间: O(N)