文章目录
- 使用的重要方法
- 一.Scanner类
- 二.冒泡排序法
- 三.for循环语句
- 四.所有代码及结果如下
使用的重要方法
这几天在学Java,发一些做的Java基础编程题。
今天做的这个题主要用了Scanner类来获取输入的数字,使用冒泡法来对数组进行排序,使用for循环来实现冒泡法和遍历数组。
一.Scanner类
我们可以通过 Scanner 类来获取用户的输入。(记得导入Scanner类的包java.util.Scanner )
下面是创建 Scanner 对象的基本语法:
Scanner sc = new Scanner(System.in);
在本题中我们要获取输入的数字所以还要使用
int n = sc.nextInt();
如果你想要获取输入的字符(不是字符串)
char p = sc.nextInt().charAt(0);
如果你想要获取输入的字符串
String s = sc.nextLine();
或
String s = sc.next();
二.冒泡排序法
前言:在这里主要只讲我在编程中我的理解,详细想要了解冒泡法可以自行去搜。
冒泡法的特性:大的降到下去,小的浮上来。
但在这题中是反用他,小的放到后面去,大的放到前面来,因为是按照从大到小的顺序。
三.for循环语句
for循环语句是这道题中最运用最多的循环语句,其一般用在循环次数已知的情况下。for循环语句的语法格式如下:
for(①初始化表达式;②循环条件;③操作表达式){
④执行语句
…
}
其具体操作流程如下:
第一步,执行①
第二步,执行②,如果判断结果为true,执行第三步,如果为false,执行第五步
第三步,执行④
第四步,执行③,然后重复执行第二步
第五步,退出循环。
四.所有代码及结果如下
import java.util.Scanner;
public class Homework01 {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int[] arr = new int[4];
for(int i=0;i<arr.length;i++){
arr[i] = sc.nextInt(); //获取输入的数字
}
System.out.println("当前数组为:");
printArray(arr);
bubbleSort(arr);
System.out.println("排序后的数组为:");
printArray(arr);
}
//打印数组
public static void printArray(int[] arr){ //形参arr,是a,b...都行,不影响
for(int i=0;i<arr.length;i++){
System.out.print(arr[i]+" ");
}
System.out.println();
}
//调用冒泡方法,对数组进行排序
public static void bubbleSort(int[] arr){ //形参arr,是a,b...都行,不影响
//第一次排序将最后一个数定为最小,第二次将倒数第二个数为第二小......
for(int i=0;i<arr.length-1;i++){ //最后只剩一个数,无需排序
//"-1"同上,最后一个数无需交换
//“-i”第i+1(i初始为0,所以+1)轮排序后就少了一个数,第2轮就少两个
for(int j=0;j<arr.length-i-1;j++){
if(arr[j]<arr[j+1]){ //如果前一个数小于后二个数就交换
int x = arr[j];
arr[j] = arr[j+1];
arr[j+1] = x;
}
}
System.out.println("第"+(i+1)+"轮排序后:");
printArray(arr);
}
}
}
7
59
68
196
当前数组为:
7 59 68 196
第1轮排序后:
59 68 196 7
第2轮排序后:
68 196 59 7
第3轮排序后:
196 68 59 7
排序后的数组为:
196 68 59 7