案列:在主持人演讲大赛中,有六位评委为选手打分,一百分制。选手最后得分为:去掉一个最高分,去掉一个最低分,在四个评委分里去平均值。
package com.code;
import java.util.Scanner;
public class grade {
public static void main(String[] args) {
double[]score=new double[6];
inputScore(score);
showScore(score);
int flag1= getMax(score);
int flag2=getMin(score);
averageScore(score,flag1,flag2);
}
//评委开始打分
public static void inputScore(double[]score){
System.out.println("输入选手得分(6个)");
Scanner sr=new Scanner(System.in);
for (int i=0;i<score.length;i++)
{
score[i]=sr.nextDouble();
}
}
//显示选手得分
public static void showScore(double[]socre){
for(int i=0;i<socre.length;i++)
{
System.out.print(socre[i]+"分");
if(i<socre.length-1)
System.out.print(", ");
}
}
//去掉一个最高分
public static int getMax(double[]score){
double max=score[0];
for(int i=0;i<score.length;i++)
{
if(max<score[i])
{
max=score[i];
}
}
System.out.println("\n最高分是:"+max);
//记录最高分的下标
int flag=0;
for(int i=0;i<score.length;i++)
{
if(max==score[i])
flag=i;
}
return flag;
}
public static int getMin(double[]score){
double min=score[0];
for(int i=0;i<score.length;i++)
{
if(min>score[i])
{
min=score[i];
}
}
System.out.println("最低分是:"+min);
//记录最高低的下标
int flag=0;
for(int i=0;i<score.length;i++)
{
if(min==score[i])
flag=i;
}
return flag;
}
public static void averageScore(double[]score,int flag1,int flag2){
double sum=0;
double average_sum=0;
for(int i=0;i<score.length;i++)
{
if(i!=flag1&&i!=flag2)
sum+=score[i];
}
average_sum=sum/(score.length-2);
System.out.print("选手总得分:");
System.out.printf("%.2f\n",sum);
System.out.print("选手最终得分:");
System.out.printf("%.2f\n",average_sum);
}
}
输出样例:
感想和分析:
在写去掉最高分和最低分的时候纠结了一下,最终我选择用记录下标的形式在计算总分时跳过最高分和最低分。
这里的flag1和flag2是用来记录数组中最高分和最低分下标的。
功能函数中用int类型既可以在函数里面输出最高分和最低分,又可以把其下标返回到信号处。在计算总分的时候可以避开它们。
其实在这一步的时候还有一种方法:计算六位评委的总分在计算平均分时减去返回的最高分和最低分。这里就不演示了。
在coding时候容易犯的错误:
average_sum=sum/score.length-2;
它的本意是计算除去最高和最低的平均分。如果被除数不打括号的话,就会出现总分/总的评委数再减2,结果会出现很大的变化。
在coding时学会的新知识:
打印函数System.out.println和System.out.print和System.out.printf的区别
println:表示输出后再换行再结束。
print:表示输出后光标仍停留在改行。
printf:可以调整输出值的格式。例如:在该案例中用的数据类型是double,最后计算的结果会过多的保留小数位数,例如我想把小数结果保留到2位,需要用到%.2f。但是用上述两中函数里会报错。
最终输出代码的调整。