JAVA中求某个数组的众数?自己写了个,但是不对
众数的定义:一组数据中出现次数最多的数称为这组数据的众数。下面是我写的方法代码publicstaticdoublemode(double[]array){Arrays.s...
众数的定义:一组数据中出现次数最多的数称为这组数据的众数。
下面是我写的方法代码
public static double mode(double[] array){
Arrays.sort(array);
int count=0; int longest=0; double mode=0;
for (int i=0; i<array.length; i++){
if(array[i]==array[i+1])
count++;
if(array[i]!=array[i+1]){
longest=count;
}
if (count>longest){
mode=array[i];
longest=count;
count=0;
}
}
return mode;
}
我自己也觉得写得不太对,但是不知道该怎么修改 展开
下面是我写的方法代码
public static double mode(double[] array){
Arrays.sort(array);
int count=0; int longest=0; double mode=0;
for (int i=0; i<array.length; i++){
if(array[i]==array[i+1])
count++;
if(array[i]!=array[i+1]){
longest=count;
}
if (count>longest){
mode=array[i];
longest=count;
count=0;
}
}
return mode;
}
我自己也觉得写得不太对,但是不知道该怎么修改 展开
2个回答
展开全部
public static double mode(double[] array) {
Arrays.sort(array);
int count = 1;
int longest = 0;
double mode = 0;
for (int i = 0; i < array.length - 1; i++) {
if (array[i] == array[i + 1]) {
count++;
} else {
count = 1;//如果不等于,就换到了下一个数,那么计算下一个数的次数时,count的值应该重新符值为一
continue;
}
if (count > longest) {
mode = array[i];
longest = count;
}
}
System.out.println(longest);//打印出这个数出现的次数已判断是否正确
return mode;
}
我运行过了,是对的
Arrays.sort(array);
int count = 1;
int longest = 0;
double mode = 0;
for (int i = 0; i < array.length - 1; i++) {
if (array[i] == array[i + 1]) {
count++;
} else {
count = 1;//如果不等于,就换到了下一个数,那么计算下一个数的次数时,count的值应该重新符值为一
continue;
}
if (count > longest) {
mode = array[i];
longest = count;
}
}
System.out.println(longest);//打印出这个数出现的次数已判断是否正确
return mode;
}
我运行过了,是对的
展开全部
帮改了下,应该是对的
public static double mode(double[] array){
Arrays.sort(array);
int count=1; int longest=0; double mode=0;
for (int i=0; i<array.length-1; i++){
if(array[i]==array[i+1])
{
count++;
if (count>longest){
mode=array[i];
longest=count;
}
else
count=1;
}
return mode;
}
你犯了几个错误,第一没有考虑边界情况,第二你重置变量的时机都不对。
public static double mode(double[] array){
Arrays.sort(array);
int count=1; int longest=0; double mode=0;
for (int i=0; i<array.length-1; i++){
if(array[i]==array[i+1])
{
count++;
if (count>longest){
mode=array[i];
longest=count;
}
else
count=1;
}
return mode;
}
你犯了几个错误,第一没有考虑边界情况,第二你重置变量的时机都不对。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询