Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,851 questions

51,772 answers

573 users

How to get the minimum elements to be deleted to make an array with same values in C++

1 Answer

0 votes
#include <iostream>
#include <limits.h>
#include <unordered_map>

int minElementsToBeDelete(int arr[], int size) {
    std::unordered_map<int, int> frequency;
    
    for (int i = 0; i < size; i++)
        frequency[arr[i]]++;
        
    int max_frequency = INT_MIN;
    
    for (auto itr = frequency.begin(); itr != frequency.end(); itr++)
        max_frequency = std::max(max_frequency, itr->second);
        
    return size - max_frequency;
}

int main()
{
    int arr[] = { 3, 5, 3, 8, 3, 3, 9, 3, 2, 2 };
    
    int size = sizeof(arr) / sizeof(arr[0]);
    
    std::cout << minElementsToBeDelete(arr, size);
}




/*
run:

5

*/

 



answered Dec 12, 2022 by avibootz
...