在Java中获取数组中最频繁的元素
在Java中,数组是一种非原始数据类型,它存储相同数据类型的多个值。
根据题目要求,我们需要找出数组中出现次数最多的元素及其频率。
数组可以包含重复值。元素在数组中出现的次数称为该元素的频率。频率最高的元素就是数组中最频繁的元素。
让我们看看如何使用Java编程语言来实现。
一些示例
示例1
Suppose the original array is {1, 2, 3, 1, 5, 7, 5, 5, 9}.
执行查找数组中出现次数最多的元素的操作后,结果将是:
最频繁的元素是:5
示例2
Suppose the original array is {7, 2, 3, 2, 5, 7, 3, 5, 9}.
执行查找数组中出现次数最多的元素的操作后,结果将是:
最频繁的元素是:7
示例3
Suppose the original array is {77, 22, 45, 22, 32, 77, 45, 77, 77}
执行查找数组中出现次数最多的元素的操作后,结果将是:
最频繁的元素是:77
算法
步骤1 - 声明并初始化一个整型数组。
步骤2 - 使用一个int变量 `max_count` 并将其初始化为0。再声明另一个int变量 `count` 来跟踪元素在数组中出现的次数。
步骤3 - 检查条件 `count > max_count`。如果是,则将 `count` 的值赋给 `max_count`。
步骤4 - 最后,打印具有 `max_count` 值的元素。
语法
要获取数组的长度(数组中的元素个数),可以使用数组的内置属性 `length`。
以下是其语法:
array.length
其中,'array' 指的是数组引用。
多种方法
我们提供了不同的方法来解决这个问题。
使用静态初始化数组元素
使用用户自定义方法
让我们逐一查看程序及其输出。
方法1:使用静态初始化数组元素
示例
在这种方法中,数组元素将在程序中初始化。然后,根据算法获取数组中最频繁的元素。
public class Main{
//main method
public static void main(String[] args){
//Declare and initialize the array elements
int[] arr = { 1, 2, 3, 1, 5, 7, 5, 5, 9 };
//get the length of the array
int n = arr.length;
int max_count = 0;
int maxfreq = 0;
//Logic implementation
for (int i = 0; i < n; i++){
int count = 0;
for (int j = 0; j < n; j++){
if (arr[i] == arr[j]){
count++;
}
}
if (count > max_count){
max_count = count;
maxfreq = arr[i];
}
}
//print the result
System.out.print("Most frequent element is: " + maxfreq);
}
}
输出
Most frequent element is: 5
方法2:使用用户自定义方法
示例
在这种方法中,数组元素将在程序中初始化。然后,通过将数组作为参数传递给用户自定义方法,并在方法内部根据算法获取数组中最频繁的元素。
public class Main{
//main method
public static void main(String[] args){
//Declare and initialize the array elements
int[] arr = { 1, 2, 3, 1, 5, 7, 5, 5, 9 };
//get the length of the array
int n = arr.length;
//call the user defined method and print the result
System.out.print("Most frequent element is: " + freq(arr, n));
}
//user defined method
public static int freq(int[] arr, int n){
int max_count = 0;
int maxfreq = 0;
//Logic implementation
for (int i = 0; i < n; i++) {
int count = 0;
for (int j = 0; j < n; j++) {
if (arr[i] == arr[j]) {
count++;
}
}
if (count > max_count) {
max_count = count;
maxfreq = arr[i];
}
}
return maxfreq;
}
}
输出
Most frequent element is: 5
在本文中,我们探讨了如何在Java中查找数组中最频繁的元素。
广告
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP