zoukankan      html  css  js  c++  java
  • java算法之冒泡排序法

    冒泡排序法 口诀:
         外层循环 0到n-1      //控制比较轮数   n 表示元素的个数
         内层循环 0到n-i-1     //控制每一轮比较次数
         两两比较做交换
    

     

    冒泡排序的优点:每进行一趟排序,就会少比较一次,因为每进行一趟排序都会找出一个较大值。

    如上例:第一趟比较之后,排在最后的一个数一定是最大的一个数,第二趟排序的时候,只需要

    比较除了最后一个数以外的其他的数,同样也能找出一个最大的数排在参与第二趟比较的数后面,

    第三趟比较的时候,只需要比较除了最后两个数以外的其他的数,以此类推……也就是说,

    没进行一趟比较,每一趟少比较一次,一定程度上减少了算法的量。

    import java.util.Scanner;

    //冒泡排序法 口诀:
    /* 外层循环 0到n-1 //控制比较轮数 n 表示元素的个数
    * 内层循环 0到n-i-1 //控制每一轮比较次数
    两两比较做交换
    */
    public class Demo03 {

    public static void main(String[] args) {

    Scanner input = new Scanner(System.in);
    int NUM = 5;
    int []a = new int[NUM];
    System.out.println("请输入数字:");

    for(int i=0;i<a.length;i++){
    a[i] = input.nextInt();
    }

    System.out.println("排序之前:");
    for (int i : a) {
    System.out.print(i+" ");
    }

    //冒泡排序实现
    for(int i=0;i<a.length-1;i++){
    for(int j=0;j<a.length-i-1;j++){
    if(a[j]>a[j+1]){
    int temp = a[j];
    a[j] = a[j+1];
    a[j+1] = temp;
    }
    }
    }

    System.out.println(" 排序之后:");
    for (int i : a) {
    System.out.print(i+" ");
    }

    }

    }

  • 相关阅读:
    Hello,world的几种写法!
    浮动与清除浮动
    css中表格的table-layout属性特殊用法
    CSS之照片集效果
    CSS之transition过渡练习
    CSS之过渡简单应用—日落西山
    CSS之立方体绘画步骤
    CSS之立体球体
    transform
    Vue.sync修饰符与this.$emit('update:xxx', newXXX)
  • 原文地址:https://www.cnblogs.com/wjxbk/p/10083964.html
Copyright © 2011-2022 走看看