您的位置:

java冒泡排序代码(java实现冒泡排序代码)

本文目录一览:

Java冒泡排序的原理?

冒泡排序是所欲排序算法里最好理解的了。

1、排序算法:

A)比较相邻的元素。如果第一个比第二个大,就交换他们两个。

B)对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。

C)针对所有的元素重复以上的步骤,除了最后一个。

D)持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

2、给你一个java的实现代码:

public class BubbleSort{

     public static void main(String[] args){

         int score[] = {67, 69, 75, 87, 89, 90, 99, 100};

         for (int i = 0; i score.length -1; i++){ //最多做n-1趟排序

             for(int j = 0 ;j score.length - i - 1; j++){ //对当前无序区间score[0......length-i-1]进行排序(j的范围很关键,这个范围是在逐步缩小的)

                 if(score[j] score[j + 1]){ //把小的值交换到后面

                     int temp = score[j];

                     score[j] = score[j + 1];

                     score[j + 1] = temp;

                 }

             }

             System.out.print("第" + (i + 1) + "次排序结果:");

             for(int a = 0; a score.length; a++){

                 System.out.print(score[a] + "\t");

             }

             System.out.println("");

         }

             System.out.print("最终排序结果:");

             for(int a = 0; a score.length; a++){

                 System.out.print(score[a] + "\t");

        }

     }

 }

java冒泡排序代码

冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

冒泡排序算法的运作如下:

比较相邻的元素。如果第一个比第二个大,就交换他们两个。

对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。

针对所有的元素重复以上的步骤,除了最后一个。

持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

public class BubbleSort{  

      public static void main(String[] args){  

          int score[] = {67, 69, 75, 87, 89, 90, 99, 100};  

          for (int i = 0; i  score.length -1; i++){    //最多做n-1趟排序  

              for(int j = 0 ;j  score.length - i - 1; j++){    //对当前无序区间score[0......length-i-1]进行排序(j的范围很关键,这个范围是在逐步缩小的)  

                  if(score[j]  score[j + 1]){    //把小的值交换到后面  

                      int temp = score[j];  

                      score[j] = score[j + 1];  

                      score[j + 1] = temp;  

                  }  

              }              

              System.out.print("第" + (i + 1) + "次排序结果:");  

              for(int a = 0; a  score.length; a++){  

                  System.out.print(score[a] + "\t");  

              }  

              System.out.println("");  

          }  

              System.out.print("最终排序结果:");  

              for(int a = 0; a  score.length; a++){  

                  System.out.print(score[a] + "\t");  

         }  

      }  

  }

用java写个冒泡排序?

冒泡排序算法:

int类型的数组:3 1 6 2 5

第一次循环:

1 3 6 2 5

1 3 6 2 5

1 3 2 6 5

1 3 2 5 6

第二次循环:

1 3 2 5

1 2 3 5

1 2 3 5

第三次循环:

1 2 3

1 2 3

。。。

  算法:取出最大的放在最后,下次就不用比较最后一个了。*/

public class BubbleSort{

    public static void main(String[] args){

        int[] a = {3,1,6,2,5};

        //开始排序

        for(int i=a.length-1;i0;i--){

            for(int j=0;ji;j++){

                if(a[j]a[j+1]){

                    //交换位置

                    int temp;

                    temp = a[j];

                    a[j] = a[j+1];

                    a[j+1] = temp;

                }

            }

        }

        //遍历

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

            System.out.println(a[i]);

        }

    }

}

下列java 代码 冒泡排序 求逐句注释 谢谢

很好懂吧? 从第一个开始 把第二个到最后一个跟他比 如果小就交换。一次循环下来第一个一定是数组中最小的。然后从第二个开始,比较第三个到最后一个。以此类推。

JAVA冒泡排序

package Test;

import java.util.Arrays;

public class Demo1 {

public static void main(String[] args) {

int[] a = {2,1,3,9,7,10,8,11,17,6};

//System.out.println(Arrays.toString(a));

sortArr(a,a.length - 1,0);

System.out.println(Arrays.toString(a));

sort(a);

System.out.println(Arrays.toString(a));

}

public static void sortArr(int[] a,int i,int j){

if(ji){

sortOne(a,i,j);

}else{

sortOne(a,--i,0);

}

}

public static void sortOne (int[] a,int i,int j){

if(i==0)return;

if(a[j + 1]  a[j]){

 int temp = a[j];

             a[j] = a[j + 1];

             a[j + 1] = temp;

}

sortArr(a,i,++j);

}

 public static void sort(int[] a)

    {

        int temp = 0;

        for (int i = a.length - 1; i  0; --i)

        {

            for (int j = 0; j  i; ++j)

            {

                if (a[j + 1]  a[j])

                {

                    temp = a[j];

                    a[j] = a[j + 1];

                    a[j + 1] = temp;

                }

            }

        }

    }

}

上面代码是从小到大排列

package Test;

import java.util.Arrays;

public class Demo1 {

public static void main(String[] args) {

Object[] a = {2,1,3,9,7,10,8,11,17,6};

sortArr(a,a.length - 1,0);

System.out.println(Arrays.toString(a));

Object[] b = {'a','m','s','b','h','e'};

sortArr(b,b.length - 1,0);

System.out.println(Arrays.toString(b));

}

public static void sortArr(Object[] a,int i,int j){

if(ji){

sortOne(a,i,j);

}else{

sortOne(a,--i,0);

}

}

public static void sortOne (Object[] a,int i,int j){

if(i==0)return;

if(a[j + 1] instanceof Integer){

if(Integer.valueOf(""+a[j + 1]) Integer.valueOf(""+ a[j])){

Object temp = a[j];

             a[j] = a[j + 1];

             a[j + 1] = temp;

}

}else if(a[j + 1] instanceof Character){

if(a[j + 1].toString().charAt(0) a[j].toString().charAt(0)){

Object temp = a[j];

             a[j] = a[j + 1];

             a[j + 1] = temp;

}

}

sortArr(a,i,++j);

}

//  public static void sort(int[] a)

//     {

//         int temp = 0;

//         for (int i = a.length - 1; i  0; --i)

//         {

//             for (int j = 0; j  i; ++j)

//             {

//                 if (a[j + 1]  a[j])

//                 {

//                     temp = a[j];

//                     a[j] = a[j + 1];

//                     a[j + 1] = temp;

//                 }

//             }

//         }

//     }

}