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;

//                 }

//             }

//         }

//     }

}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/240183.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 12:20
下一篇 2024-12-12 12:20

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Python字符串宽度不限制怎么打代码

    本文将为大家详细介绍Python字符串宽度不限制时如何打代码的几个方面。 一、保持代码风格的统一 在Python字符串宽度不限制的情况下,我们可以写出很长很长的一行代码。但是,为了…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python基础代码用法介绍

    本文将从多个方面对Python基础代码进行解析和详细阐述,力求让读者深刻理解Python基础代码。通过本文的学习,相信大家对Python的学习和应用会更加轻松和高效。 一、变量和数…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29

发表回复

登录后才能评论