给定一个由n 个正整数组成的数组,其中包含许多重复元素。任务是找到任何两个不同元素的频率之间的最大差异,使得频率更高的元素的值也大于第二个整数。
例子:
Input : arr[] = { 3, 1, 3, 2, 3, 2 }.
Output : 2
Frequency of 3 = 3.
Frequency of 2 = 2.
Frequency of 1 = 1.
Here difference of frequency of element 3 and 1 is = 3 - 1 = 2.
Also 3 > 1.
方法一(使用哈希):
天真的方法可以是,找到每个元素的频率,并为每个元素找到比当前元素具有更小值和更低频率的元素。
下面是这个方法的实现:
C++
// C++ program to find maximum difference
// between frequency of any two element
// such that element with greater frequency
// is also greater in value.
#include
using namespace std;
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
int maxdiff(int arr[], int n)
{
unordered_map freq;
// Finding the frequency of each element.
for (int i = 0; i < n; i++)
freq[arr[i]]++;
int ans = 0;
for (int i=0; i freq[arr[j]] &&
arr[i] > arr[j] )
ans = max(ans, freq[arr[i]]-freq[arr[j]]);
else if (freq[arr[i]] < freq[arr[j]] &&
arr[i] < arr[j] )
ans = max(ans, freq[arr[j]]-freq[arr[i]]);
}
}
return ans;
}
// Driven Program
int main()
{
int arr[] = { 3, 1, 3, 2, 3, 2 };
int n = sizeof(arr)/sizeof(arr[0]);
cout << maxdiff(arr, n) << endl;
return 0;
}
Java
// Java program to find maximum difference
// between frequency of any two element
// such that element with greater frequency
// is also greater in value.
import java.util.*;
class GFG
{
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
static int maxdiff(int arr[], int n)
{
Map freq = new HashMap<>();
// Finding the frequency of each element.
for (int i = 0; i < n; i++)
freq.put(arr[i],
freq.get(arr[i]) == null ? 1 :
freq.get(arr[i]) + 1);
int ans = 0;
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
// finding difference such that element
// having greater frequency is also
// greater in value.
if (freq.get(arr[i]) > freq.get(arr[j]) &&
arr[i] > arr[j])
ans = Math.max(ans, freq.get(arr[i]) -
freq.get(arr[j]));
else if (freq.get(arr[i]) < freq.get(arr[j]) &&
arr[i] < arr[j] )
ans = Math.max(ans, freq.get(arr[j]) -
freq.get(arr[i]));
}
}
return ans;
}
// Driver Code
public static void main(String[] args)
{
int arr[] = { 3, 1, 3, 2, 3, 2 };
int n = arr.length;
System.out.println(maxdiff(arr, n));
}
}
// This code is contributed by 29AjayKumar
Python3
# Python program to find maximum difference
# between frequency of any two element
# such that element with greater frequency
# is also greater in value.
from collections import defaultdict
# Return the maximum difference between
# frequencies of any two elements such that
# element with greater frequency is also
# greater in value.
def maxdiff(arr, n):
freq = defaultdict(lambda: 0)
# Finding the frequency of each element.
for i in range(n):
freq[arr[i]] += 1
ans = 0
for i in range(n):
for j in range(n):
# finding difference such that element
# having greater frequency is also
# greater in value.
if freq[arr[i]] > freq[arr[j]] and arr[i] > arr[j]:
ans = max(ans, freq[arr[i]] - freq[arr[j]])
elif freq[arr[i]] < freq[arr[j]] and arr[i] < arr[j]:
ans = max(ans, freq[arr[j]] - freq[arr[i]])
return ans
arr = [3,1,3,2,3,2]
n = len(arr)
print(maxdiff(arr,n))
# This code is contributed by Shrikant13
C#
// C# program to find maximum difference
// between frequency of any two element
// such that element with greater frequency
// is also greater in value.
using System;
using System.Collections.Generic;
class GFG
{
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
static int maxdiff(int[] arr, int n)
{
Dictionary freq = new Dictionary();
// Finding the frequency of each element.
for (int i = 0; i < n; i++)
{
if (freq.ContainsKey(arr[i]))
freq[arr[i]]++;
else
freq.Add(arr[i], 1);
}
int ans = 0;
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
// finding difference such that element
// having greater frequency is also
// greater in value.
if (freq[arr[i]] > freq[arr[j]] && arr[i] > arr[j])
ans = Math.Max(ans, freq[arr[i]] - freq[arr[i]]);
else if (freq[arr[i]] < freq[arr[j]] && arr[i] < arr[j])
ans = Math.Max(ans, freq[arr[j]] - freq[arr[i]]);
}
}
return ans;
}
// Driver Code
public static void Main(String[] args)
{
int[] arr = { 3, 1, 3, 2, 3, 2 };
int n = arr.Length;
Console.WriteLine(maxdiff(arr, n));
}
}
// This code is contributed by
// sanjeev2552
Javascript
C++
// Efficient C++ program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
#include
using namespace std;
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
int maxdiff(int arr[], int n)
{
unordered_map freq;
int dist[n];
// Finding the frequency of each element.
int j = 0;
for (int i = 0; i < n; i++)
{
if (freq.find(arr[i]) == freq.end())
dist[j++] = arr[i];
freq[arr[i]]++;
}
// Sorting the distinct element
sort(dist, dist + j);
int min_freq = n+1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for (int i=0; i
Java
// Efficient Java program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
import java.util.*;
class GFG
{
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
static int maxdiff(int arr[], int n)
{
HashMap freq= new HashMap<>();
int []dist = new int[n];
// Finding the frequency of each element.
int j = 0;
for (int i = 0; i < n; i++)
{
dist[j++] = arr[i];
if (!freq.containsKey(arr[i]))
freq.put(arr[i], 1);
else
freq.put(arr[i], freq.get(arr[i]) + 1);
}
// Sorting the distinct element
Arrays.sort(dist);
int min_freq = n + 1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for (int i = 0; i < j; i++)
{
int cur_freq = freq.get(dist[i]);
ans = Math.max(ans, cur_freq - min_freq);
min_freq = Math.min(min_freq, cur_freq);
}
return ans;
}
// Driven Program
public static void main(String[] args)
{
int arr[] = { 3, 1, 3, 2, 3, 2 };
int n = arr.length;
System.out.print(maxdiff(arr, n) +"\n");
}
}
// This code is contributed by Rajput-Ji
Python3
# Efficient Python3 program to find maximum
# difference between frequency of any two
# elements such that element with greater
# frequency is also greater in value.
# Return the maximum difference between
# frequencies of any two elements such that
# element with greater frequency is also
# greater in value.
def maxdiff(arr, n):
freq = {}
dist = [0] * n
# Finding the frequency of each element.
j = 0
for i in range(n):
if (arr[i] not in freq):
dist[j] = arr[i]
j += 1
freq[arr[i]] = 0
if (arr[i] in freq):
freq[arr[i]] += 1
dist = dist[:j]
# Sorting the distinct element
dist.sort()
min_freq = n + 1
# Iterate through all sorted distinct elements.
# For each distinct element, maintaining the
# element with minimum frequency than that
# element and also finding the maximum
# frequency difference
ans = 0
for i in range(j):
cur_freq = freq[dist[i]]
ans = max(ans, cur_freq - min_freq)
min_freq = min(min_freq, cur_freq)
return ans
# Driven Program
arr = [3, 1, 3, 2, 3, 2]
n = len(arr)
print(maxdiff(arr, n))
# This code is contributed by SHUBHAMSINGH10
C#
// Efficient C# program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
using System.Collections.Generic;
using System;
class GFG{
// Return the maximum difference between
// frequencies of any two elements such
// that element with greater frequency
// is also greater in value.
static int maxdiff(int []arr, int n)
{
Dictionary freq = new Dictionary();
List dist = new List();
// Finding the frequency of each element.
int j = 0;
for(int i = 0; i < n; i++)
{
if (freq.ContainsKey(arr[i]) == false)
{
dist.Add(arr[i]);
j++;
}
if (freq.ContainsKey(arr[i]))
freq[arr[i]]++;
else
freq[arr[i]]=1;
}
// Sorting the distinct element
dist.Sort();
int min_freq = n + 1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for(int i = 0; i < j; i++)
{
int cur_freq = freq[dist[i]];
ans = Math.Max(ans, cur_freq - min_freq);
min_freq = Math.Min(min_freq, cur_freq);
}
return ans;
}
// Driver code
public static void Main(String[] args)
{
int []arr = { 3, 1, 3, 2, 3, 2 };
int n = arr.Length;
Console.WriteLine(maxdiff(arr, n));
}
}
// This code is contributed by Stream_Cipher
Javascript
输出:
2
时间复杂度: O(n 2 )。方法2(使用散列和排序):
这个想法是找到所有不同的元素并存储在一个数组中,比如 dist[]。按升序对不同的元素数组 dist[] 进行排序。现在对于索引 i 处的任何不同元素,对于所有索引 j 使得 i > j > 0,找到索引 0 到 i-1 之间频率最低的元素。我们可以通过与方法1相同的方式找到元素的频率,即将频率存储在哈希表中。
因此,对所有 i 执行此操作并找到最大差异。为了找到所有的最小频率,我保持一个前缀最小值。
下面是这种方法的代表:
C++
// Efficient C++ program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
#include
using namespace std;
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
int maxdiff(int arr[], int n)
{
unordered_map freq;
int dist[n];
// Finding the frequency of each element.
int j = 0;
for (int i = 0; i < n; i++)
{
if (freq.find(arr[i]) == freq.end())
dist[j++] = arr[i];
freq[arr[i]]++;
}
// Sorting the distinct element
sort(dist, dist + j);
int min_freq = n+1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for (int i=0; i
Java
// Efficient Java program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
import java.util.*;
class GFG
{
// Return the maximum difference between
// frequencies of any two elements such that
// element with greater frequency is also
// greater in value.
static int maxdiff(int arr[], int n)
{
HashMap freq= new HashMap<>();
int []dist = new int[n];
// Finding the frequency of each element.
int j = 0;
for (int i = 0; i < n; i++)
{
dist[j++] = arr[i];
if (!freq.containsKey(arr[i]))
freq.put(arr[i], 1);
else
freq.put(arr[i], freq.get(arr[i]) + 1);
}
// Sorting the distinct element
Arrays.sort(dist);
int min_freq = n + 1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for (int i = 0; i < j; i++)
{
int cur_freq = freq.get(dist[i]);
ans = Math.max(ans, cur_freq - min_freq);
min_freq = Math.min(min_freq, cur_freq);
}
return ans;
}
// Driven Program
public static void main(String[] args)
{
int arr[] = { 3, 1, 3, 2, 3, 2 };
int n = arr.length;
System.out.print(maxdiff(arr, n) +"\n");
}
}
// This code is contributed by Rajput-Ji
蟒蛇3
# Efficient Python3 program to find maximum
# difference between frequency of any two
# elements such that element with greater
# frequency is also greater in value.
# Return the maximum difference between
# frequencies of any two elements such that
# element with greater frequency is also
# greater in value.
def maxdiff(arr, n):
freq = {}
dist = [0] * n
# Finding the frequency of each element.
j = 0
for i in range(n):
if (arr[i] not in freq):
dist[j] = arr[i]
j += 1
freq[arr[i]] = 0
if (arr[i] in freq):
freq[arr[i]] += 1
dist = dist[:j]
# Sorting the distinct element
dist.sort()
min_freq = n + 1
# Iterate through all sorted distinct elements.
# For each distinct element, maintaining the
# element with minimum frequency than that
# element and also finding the maximum
# frequency difference
ans = 0
for i in range(j):
cur_freq = freq[dist[i]]
ans = max(ans, cur_freq - min_freq)
min_freq = min(min_freq, cur_freq)
return ans
# Driven Program
arr = [3, 1, 3, 2, 3, 2]
n = len(arr)
print(maxdiff(arr, n))
# This code is contributed by SHUBHAMSINGH10
C#
// Efficient C# program to find maximum
// difference between frequency of any two
// elements such that element with greater
// frequency is also greater in value.
using System.Collections.Generic;
using System;
class GFG{
// Return the maximum difference between
// frequencies of any two elements such
// that element with greater frequency
// is also greater in value.
static int maxdiff(int []arr, int n)
{
Dictionary freq = new Dictionary();
List dist = new List();
// Finding the frequency of each element.
int j = 0;
for(int i = 0; i < n; i++)
{
if (freq.ContainsKey(arr[i]) == false)
{
dist.Add(arr[i]);
j++;
}
if (freq.ContainsKey(arr[i]))
freq[arr[i]]++;
else
freq[arr[i]]=1;
}
// Sorting the distinct element
dist.Sort();
int min_freq = n + 1;
// Iterate through all sorted distinct elements.
// For each distinct element, maintaining the
// element with minimum frequency than that
// element and also finding the maximum
// frequency difference
int ans = 0;
for(int i = 0; i < j; i++)
{
int cur_freq = freq[dist[i]];
ans = Math.Max(ans, cur_freq - min_freq);
min_freq = Math.Min(min_freq, cur_freq);
}
return ans;
}
// Driver code
public static void Main(String[] args)
{
int []arr = { 3, 1, 3, 2, 3, 2 };
int n = arr.Length;
Console.WriteLine(maxdiff(arr, n));
}
}
// This code is contributed by Stream_Cipher
Javascript
输出:
2
时间复杂度: O(n log n)。
如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程和学生竞争性编程现场课程。