在 C++ 中数组中查找出现最频繁的元素
本文将演示有关如何在数组 C++ 中查找出现最频繁的元素的多种方法。
使用 std::sort
算法与迭代法来寻找数组中最频繁的元素
在数组中查找最频繁的元素的简单方法是遍历数组的排序版本并保留元素频率的计数。在这种情况下,我们假设数组是整数序列,它们存储在 std::vector
容器中。
首先,我们需要使用 std::sort
算法对整数数组进行排序,使一次遍历足以找到最频繁的元素。注意,在迭代过程中我们需要几个变量。即,我们存储最后一次迭代中的整数以与当前元素进行比较;同样,我们在循环的每个循环中都更新最频繁的整数的值。该算法检查当前元素是否等于前一个元素,并在表达式为真时递增频率计数器。如果不为真,则检查当前频率计数是否大于到目前为止遇到的最大值,如果是,则存储最大频率计数和最频繁元素的更新值。
然后,我们修改之前的整数变量,并将当前频率重置为 1
。循环结束后,还有一个 if
条件可以比较当前频率和最大频率,然后我们可以确定结果元素。
#include <iostream>
#include <string>
#include <vector>
using std::cout; using std::cin;
using std::vector; using std::sort;
using std::endl;
int getMostFrequentElement(vector<int> &arr)
{
if (arr.empty())
return -1;
sort(arr.begin(), arr.end());
auto last_int = arr.front();
auto most_freq_int = arr.front();
int max_freq = 0, current_freq = 0;
for (const auto &i : arr) {
if (i == last_int)
++current_freq;
else {
if (current_freq > max_freq) {
max_freq = current_freq;
most_freq_int = last_int;
}
last_int = i;
current_freq = 1;
}
}
if (current_freq > max_freq) {
max_freq = current_freq;
most_freq_int = last_int;
}
return most_freq_int;
}
int main(){
vector<int> arr = { 1,2,3,4,5,6,7,8,9,10,
2,3,4,5,6,7,8,9,10,10,
2,3,4,5,6,7,8,9,10,10 };
int ret = getMostFrequentElement(arr);
if (ret == -1) {
perror("getMostFrequentElement");
exit(EXIT_FAILURE);
}
cout << "Most frequent element = " << ret << endl;
exit(EXIT_SUCCESS);
}
输出:
Most frequent element = 10
将 std::unordered_map
容器与 std::max_element
函数一起使用以查找数组中最频繁的元素
另外,我们可以利用 std::unordered_map
类为每个元素累积频率,然后调用 std::max_element
算法来识别具有最大值的元素。请注意,累积频率需要遍历整个数组,并且每次迭代都需要在映射中插入。在这种情况下,std::max_element
方法采用三个参数,前两个参数:范围的开始和结束说明符。第三个参数是 lambda 函数,用于比较 std::unordered_map
类型为 std::pair
的元素。最后,我们可以从返回的 max_element
对算法中返回第二项。
#include <iostream>
#include <string>
#include <vector>
#include <unordered_map>
using std::cout; using std::cin;
using std::endl; using std::unordered_map;
using std::vector; using std::sort;
int getMostFrequentElement(vector<int> &arr)
{
if (arr.empty())
return -1;
unordered_map<int, int> freq_count;
for (const auto &item : arr)
freq_count[item]++;
auto most_freq_int =
std::max_element(freq_count.begin(), freq_count.end(),
[] (const auto &x, const auto &y) {return x.second < y.second;});
return most_freq_int->first;
}
int main(){
vector<int> arr = { 1,2,3,4,5,6,7,8,9,10,
2,3,4,5,6,7,8,9,10,10,
2,3,4,5,6,7,8,9,10,10 };
int ret = getMostFrequentElement(arr);
if (ret == -1) {
perror("getMostFrequentElement");
exit(EXIT_FAILURE);
}
cout << "Most frequent element = " << ret << endl;
exit(EXIT_SUCCESS);
}
输出:
Most frequent element = 10
相关文章
在 C++ 中通过掷骰子生成随机值
发布时间:2023/04/09 浏览次数:169 分类:C++
-
本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。
在 C++ 中使用模板的链表
发布时间:2023/04/09 浏览次数:158 分类:C++
-
本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。
在 C++ 中添加定时延迟
发布时间:2023/04/09 浏览次数:142 分类:C++
-
本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。
在 C++ 中创建查找表
发布时间:2023/04/09 浏览次数:155 分类:C++
-
本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。
如何在 C++ 中把字符串转换为小写
发布时间:2023/04/09 浏览次数:63 分类:C++
-
介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码
如何在 C++ 中确定一个字符串是否是数字
发布时间:2023/04/09 浏览次数:163 分类:C++
-
本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。
如何在 c++ 中查找字符串中的子字符串
发布时间:2023/04/09 浏览次数:65 分类:C++
-
本文介绍了在 C++ 中检查一个字符串是否包含子字符串的多种方法。使用 find 方法在 C++ 中查找字符串中的子字符串
如何在 C++ 中把字符串转换为 Char 数组
发布时间:2023/04/09 浏览次数:107 分类:C++
-
本文介绍了在 C++ 中把字符串转换为 char 数组的多种方法。使用 std::basic_string::c_str 方法将字符串转换为 char 数组