冒泡排序法(自己输入数据)


文章目录

使用的重要方法

         一.Scanner类

         二.冒泡排序法

         三.for循环语句

         四.所有代码及结果如下

使用的重要方法

这几天在学Java,发一些做的Java基础编程题。今天做的这个题主要用了Scanner类来获取输入的数字,使用冒泡法来对数组进行排序,使用for循环来实现冒泡法和遍历数组。

一.Scanner类

我们可以通过 Scanner 类来获取用户的输入。(记得导入Scanner类的包java.util.Scanner )

下面是创建Scanner对象的基本语法: 

Scanner sc=new Scanner(System.in);

在本题中我们要获取输入的数字还要使用

            int[] a=new int[10];
            Scanner sc=new Scanner(System.in);
            for(int b=0;b<a.length;b++){
           //利用for循环输入需要判断的十个数
            a[b]=sc.nextInt();

 二.冒泡排序法

前言:在这里主要只讲我在编程中我的理解,详细想要了解冒泡法可以自行去搜。冒泡法的特性:大的降到下去,小的浮上来。但在这题中是反用他,小的放到后面去,大的放到前面来,因为是按照从大到小的顺序。

三.for循环语句

for循环语句是这道题中最运用最多的循环语句,其一般用在循环次数已知的情况下。for循环语句的语法格式如下:

for(①初始化表达式;②循环条件;③操作表达式){

④执行语句

}

其具体操作流程如下:

第一步,执行①

第二步,执行②,如果判断结果为true,执行第三步,如果为false,执行第五步

第三步,执行④\n第四步,执行③,然后重复执行第二步

第五步,退出循环。

四.所有代码及结果如下

运行结果:

 代码如下:

import java.util.Scanner;
public class code {
    public static void main(String[] args){
        //输入十个数按冒泡法降序(从大到小)排序
        int[] a=new int[10];
       Scanner sc=new Scanner(System.in);
       System.out.print("请输入需要排序的十个数:");
       //通过数组的length属性获得数组长度
       for(int b=0;b<a.length;b++){
           //利用for循环输入需要判断的十个数
            a[b]=sc.nextInt();
       }
       //外层循环表示要比较的趟数(n个数比较n-1趟)
      for(int x=1;x<a.length;x++){
          /*第一趟(x=1时)数值共比较了9次(也就是a.length-1次)确定了a[9]为最小值
          第二躺(x=2时)数值共比较了8次(也就是a.length-2次)确定了最后两位(a[8],a[9])的值
          第x躺数值共比较了a.length-x次
           */
          for(int y=1;y<=a.length-x;y++){
              //判断比较是否进行换位
              if(a[y]>a[y-1]){
                  //表达式为true时z用来配合交换a[y]和a[y-1]的值
                  int z=0;
                  z=a[y];
                  a[y]=a[y-1];
                  a[y-1]=z;
              }
          }
      }
      System.out.print("输入的十个数从大到小排序为:");
      //将排好序的数组利用for循环依次输出
      for(int x=0;x<a.length;x++)
          System.out.print(a[x]+"\t");
    }
}
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

L舍予

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值