给定一个整数数组,删除严格小于k次的所有元素。
例子:
Input : arr[] = {1, 2, 2, 3, 2, 3, 4}
k = 2
Output : 2 2 3 2 3
Explanation : {1, 4} appears less than 2 times.
方法 :
- 拿一个哈希图,它将存储数组中所有元素的频率。
- 现在,再次遍历。
- 删除严格少于k次的元素。
- 否则,打印它。
C++
// C++ program to remove the elements which
// appear strictly less than k times from the array.
#include "iostream"
#include "unordered_map"
using namespace std;
void removeElements(int arr[], int n, int k)
{
// Hash map which will store the
// frequency of the elements of the array.
unordered_map mp;
for (int i = 0; i < n; ++i) {
// Incrementing the frequency
// of the element by 1.
mp[arr[i]]++;
}
for (int i = 0; i < n; ++i) {
// Print the element which appear
// more than or equal to k times.
if (mp[arr[i]] >= k) {
cout << arr[i] << " ";
}
}
}
int main()
{
int arr[] = { 1, 2, 2, 3, 2, 3, 4 };
int n = sizeof(arr) / sizeof(arr[0]);
int k = 2;
removeElements(arr, n, k);
return 0;
}
Java
// Java program to remove the elements which
// appear strictly less than k times from the array.
import java.util.HashMap;
class geeks
{
public static void removeElements(int[] arr,
int n, int k)
{
// Hash map which will store the
// frequency of the elements of the array.
HashMap mp = new HashMap<>();
for (int i = 0; i < n; ++i)
{
// Incrementing the frequency
// of the element by 1.
if (!mp.containsKey(arr[i]))
mp.put(arr[i], 1);
else
{
int x = mp.get(arr[i]);
mp.put(arr[i], ++x);
}
}
for (int i = 0; i < n; ++i)
{
// Print the element which appear
// more than or equal to k times.
if (mp.get(arr[i]) >= k)
System.out.print(arr[i] + " ");
}
}
// Driver code
public static void main(String[] args)
{
int[] arr = { 1, 2, 2, 3, 2, 3, 4 };
int n = arr.length;
int k = 2;
removeElements(arr, n, k);
}
}
// This code is contributed by
// sanjeev2552
Python3
# Python3 program to remove the elements which
# appear strictly less than k times from the array.
def removeElements(arr, n, k):
# Hash map which will store the
# frequency of the elements of the array.
mp = dict()
for i in range(n):
# Incrementing the frequency
# of the element by 1.
mp[arr[i]] = mp.get(arr[i], 0) + 1
for i in range(n):
# Print the element which appear
# more than or equal to k times.
if (arr[i] in mp and mp[arr[i]] >= k):
print(arr[i], end = " ")
# Driver Code
arr = [1, 2, 2, 3, 2, 3, 4]
n = len(arr)
k = 2
removeElements(arr, n, k)
# This code is contributed by Mohit Kumar
C#
// C# program to remove the elements which
// appear strictly less than k times from the array.
using System;
using System.Collections.Generic;
class geeks
{
public static void removeElements(int[] arr,
int n, int k)
{
// Hash map which will store the
// frequency of the elements of the array.
Dictionary mp = new Dictionary();
for (int i = 0; i < n; ++i)
{
// Incrementing the frequency
// of the element by 1.
if (!mp.ContainsKey(arr[i]))
mp.Add(arr[i], 1);
else
{
int x = mp[arr[i]];
mp[arr[i]] = mp[arr[i]] + ++x;
}
}
for (int i = 0; i < n; ++i)
{
// Print the element which appear
// more than or equal to k times.
if (mp[arr[i]] >= k)
Console.Write(arr[i] + " ");
}
}
// Driver code
public static void Main(String[] args)
{
int[] arr = { 1, 2, 2, 3, 2, 3, 4 };
int n = arr.Length;
int k = 2;
removeElements(arr, n, k);
}
}
// This code is contributed by Rajput-Ji
Python3
# Python3 program to remove the elements which
# appear strictly less than k times from the array.
from collections import Counter
def removeElements(arr, n, k):
# Calculating frequencies using
# Counter function
freq = Counter(arr)
for i in range(n):
# Print the element which appear
# more than or equal to k times.
if (freq[arr[i]] >= k):
print(arr[i], end=" ")
# Driver Code
arr = [1, 2, 2, 3, 2, 3, 4]
n = len(arr)
k = 2
removeElements(arr, n, k)
# This code is contributed by vikkycirus
输出:
2 2 3 2 3
时间复杂度: O(N)
方法2:使用内置的Python函数:
- 使用Counter()函数计算每个元素的频率
- 遍历数组。
- 删除严格少于k次的元素。
- 否则,打印它。
下面是上述方法的实现:
Python3
# Python3 program to remove the elements which
# appear strictly less than k times from the array.
from collections import Counter
def removeElements(arr, n, k):
# Calculating frequencies using
# Counter function
freq = Counter(arr)
for i in range(n):
# Print the element which appear
# more than or equal to k times.
if (freq[arr[i]] >= k):
print(arr[i], end=" ")
# Driver Code
arr = [1, 2, 2, 3, 2, 3, 4]
n = len(arr)
k = 2
removeElements(arr, n, k)
# This code is contributed by vikkycirus
输出:
2 2 3 2 3