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
using System;
using System.Collections.Generic;

public class Example
{
	public static int minElementsToBeDelete(int[] arr) {
		Dictionary<int, int> frequency = new Dictionary<int, int>();
		int size = arr.Length;

		for (int i = 0; i < size; i++) {
			if (frequency.ContainsKey(arr[i])) {
				frequency[arr[i]] = frequency[arr[i]] + 1;
			}
			else {
				frequency[arr[i]] = 1;
			}
		}

		int max_frequency = int.MinValue;
		foreach (int i in frequency.Keys) {
			max_frequency = Math.Max(max_frequency, frequency[i]);
		}

		return size - max_frequency;
	}

	public static void Main(string[] args) {
		int[] arr = new int[] {3, 5, 3, 8, 3, 3, 9, 3, 2, 2};

		Console.WriteLine(minElementsToBeDelete(arr));
	}
}



/*
run:

5

*/

 



answered Dec 12, 2022 by avibootz
...