请问哪里错了??/

来源:7-1 编程练习

慕少8138617

2020-02-18 10:30

public class HelloWorld {

    

    //完成 main 方法

    public static void main(String[] args) {

    int[] score={89,23,64,91,119,52,73} ;   

     HelloWorld hello=new HelloWorld();   

        hello.print(score);

        

    }

    

    //定义方法完成成绩排序并输出前三名的功能

    public void print(int scores[])

    {int a;

        for(int i=0;i<scores.length;i++){

            if(scores[i]>scores[i-1]){

                a=scores[i];

                scores[i]=scores[i-1];

                scores[i-1]=a;

            }

        }

        for(int i=0;i<3;i++){

            System.out.print(scores[i]);

        }

    }

    

    

    


写回答 关注

2回答

  • 慕少8494568
    2020-02-19 11:33:40

    import java.util.Arrays;

    public class HelloWorld {

        

        //完成 main 方法

        public static void main(String[] args) {

            

            int[] scores = {89,-23,64,91,119,52,73};

            HelloWorld hw = new HelloWorld();

            hw.sort3(scores);

            for(int ii= 3; ii>0; ii--)

            {

                System.out.println(scores[scores.length-ii]);

            }

        }

        

        //定义方法完成成绩排序并输出前三名的功能

        

        public void sort3(int[] scores)

        {

            Arrays.sort(scores);

        }


  • 慕桂英2493072
    2020-02-18 12:18:50

    你这个也不是冒泡排序法啊, 而且还存在数组越界

     for(int i=0;i<scores.length;i++){

                if(scores[i]>scores[i-1]){

                    a=scores[i];

                    scores[i]=scores[i-1];

                    scores[i-1]=a;

    就是这段

    真正的冒泡排序是这样的

     for(int i=1;i<scores.length;i++)

        for(int j=0; j<scores.length-i;j++)     

           if(scores[j]<scores[j+1]){

                    a=scores[j];

                    scores[j]=scores[j+1];

                    scores[j+1]=a;

                    }


Java入门第一季(IDEA工具)升级版

0基础萌新入门第一课,从Java环境搭建、工具使用、基础语法开始

1165644 学习 · 17587 问题

查看课程

相似问题