在一堆数中找出现最多的数!并且在有相同最多个数的前提下从大到小排序后输出!
对于此问题,我们可以把解题过程总体分为两个步骤:找最多出现次数的数、排序。我这里解决问题的核心是采用java中的集合知识,比如清空集合、向集合添加元素、集合排序等。
java中集合提供了很多便捷的方法,极大地简化了我们写代码时中的许多步骤。这些方法一看便能见名知意,再加上idea的在我们输入后的智能提示,对编程人员更加友好。集合需要我们大家去努力学习,多去用它,久而久之我们便会发现自己使用起来更加得心应手。
下面给出解决此问题的代码,供大家学习,参考。
import java.util.*;
public class Main{
public static void main(String[] args) {
Scanner s = new Scanner(System.in);
int n=s.nextInt();
int[] nums=new int[n];
for (int i = 0; i < n; i++) {
nums[i]=s.nextInt();//读取数据到数组中
}
int max=0,count;
ArrayList<Integer> list = new ArrayList<>();
for (int i = 0; i < n; i++) {
count=0;
if(list.contains(nums[i]))//若遇到之前算过的数就跳过执行,提高效率
continue;
for (int i2 = 0; i2 < n; i2++) {
if(nums[i2]==nums[i]){
count++;
}
}
if(count>max){
max=count;
if(!list.isEmpty()){//要判断集合非空,不然执行下面的语句会报异常
list.clear();//存在比之前数量多的就清空前面得出的结果
}
list.add(nums[i]);
}
else if(max==count){
list.add(nums[i]);
}
}
Collections.reverse(list);//给集合中的元素从大到小输出
// for (Integer i : list) {
// System.out.println(i);
// }
System.out.println("出现次数最多的数为:"+list.toString().replace("[","").replace("]",""));
}
}
补充说明:这里其实也可以不用集合,可以取而代之用数据结构中的链表,大家可以去试试哦。
【希望这篇博文能够给迷茫的博友指明方向,或能够减少迷茫,帮助到正需要帮助的人。】
最后,如果有博友有更好的想法,欢迎在评论区留言,我们一起学习,共同进步!