初学者Java编程IF-ELSE语句效率低下的代码



我的代码正确,但看起来太大。我想知道它是否更有效,更少的变量。您有任何提示吗?谢谢

样本输出

输入三个分数:87 42 94

最低分数是:42
没有最低分数的平均值为:90.5
等级是:a

<code>
import java.util.Scanner;
public class GradeAverager
{
public static void main(String[] args) 
    {
       int score1,score2,score3;
       double average,average_no_lowest;
       Scanner keyboard = new Scanner(System.in);
       System.out.print("Enter three scores: ");
       score1 = keyboard.nextInt();
       score2 = keyboard.nextInt();
       score3 = keyboard.nextInt();
       average = (score1 + score2 + score3) / 3.0;
       System.out.println();
       System.out.println("The average is: " + average);

       if (score1 < score2 && score1 < score3)
             System.out.println("The lowest score was:" + score1);
       else if (score2 < score1 && score2 < score3)
             System.out.println("The lowest score was:" + score2);
       else if (score3 < score1 && score3 < score2)
             System.out.println("The lowest score was:" + score3);

       if (score1 < score2 && score1 < score3){
             average_no_lowest = (score2 + score3)/2.0; 
             System.out.println("The average without the lowest score is: " + average_no_lowest);
             if(average_no_lowest > 90)
                  System.out.print('A');
             else if(average_no_lowest < 90 && average_no_lowest > 80 )
                  System.out.print('B');
             else if(average_no_lowest > 70 && average_no_lowest < 80)
                  System.out.print('C'); 
             else
                  System.out.print('D');
             }
       else if (score2 < score1 && score2 < score3){
             average_no_lowest = (score1 + score3)/2.0;
             System.out.println("The average without the lowest score is: " + average_no_lowest);
             if(average_no_lowest > 90)
                  System.out.print('A');
             else if(average_no_lowest < 90 && average_no_lowest > 80 )
                  System.out.print('B');
             else if(average_no_lowest > 70 && average_no_lowest < 80)
                  System.out.print('C'); 
             else
                  System.out.print('D');
             }
       else if (score3 < score1 && score3 < score2){
             average_no_lowest =(score1 + score3)/2.0;
             System.out.println("The average without the lowest score is: " + (score1 + score3)/2.0);
             if(average_no_lowest > 90)
                  System.out.print('A');
             else if(average_no_lowest < 90 && average_no_lowest > 80 )
                  System.out.print('B');
             else if(average_no_lowest > 70 && average_no_lowest < 80)
                  System.out.print('C'); 
             else
                  System.out.print('D');     
             }
    }
}
</code>

您的代码部分读取

if(average_no_lowest > 90)
    System.out.print('A');
else if(average_no_lowest < 90 && average_no_lowest > 80 )
    System.out.print('B');
else if(average_no_lowest > 70 && average_no_lowest < 80)
    System.out.print('C'); 
else
    System.out.print('D');
}

重复3次。将其放入方法中。

直到一个可靠的问题之前,不要担心性能。担心阅读和维护代码有多容易。

代码有2个受众 - 编译器和人类。人类比编译器重要。

将最低分数存储在变量中。最低_score。并按平均(总数 - low_score)/2进行平均这是最有效的

您可以使用以下代码,这些代码的代码较少,并提供相同的输出::

   public static void main(String[] args) {
    int score1, score2, score3, status;
    double average, average_no_lowest;
    Scanner keyboard = new Scanner(System.in);
    System.out.print("Enter three scores: ");
    score1 = keyboard.nextInt();
    score2 = keyboard.nextInt();
    score3 = keyboard.nextInt();
    average = (score1 + score2 + score3) / 3;
    System.out.println("Average Score was:: " + average);
    if (score1 < score2 && score1 < score3) {
        status = 1;
        System.out.println("The lowest score was:: " + score1);
    } else if (score2 < score1 && score2 < score3) {
        status = 2;
        System.out.println("The lowest score was:: " + score2);
    } else {
        status = 3;
        System.out.println("The lowest score was:: " + score3);
    }
    if (status == 1) {
        average_no_lowest = (score2 + score3) / 2;
        System.out.println("The average without the lowest score is: "
                + average_no_lowest);
    } else if (status == 2) {
        average_no_lowest = (score1 + score3) / 2;
        System.out.println("The average without the lowest score is: "
                + average_no_lowest);
    } else {
        average_no_lowest = (score1 + score2) / 2;
        System.out.println("The average without the lowest score is: "
                + average_no_lowest);
    }
}

最新更新