核心
1、把待排序的元素插入到上一步已经排好序的列表里去。
2、时间复杂度为O(n^2)
<span style="font-size:14px;">public class MyInsertSort {
static int[] array;
public static void main(String[] args) {
input();
insertSort(array);
output();
}
static void insertSort(int[] array){
if(array==null || array.length<2){ //输入为空或输入一个元素时,直接返回。
return;
}
for(int i=1;i<array.length;i++){ // 从第二个元素开始,每次向一个有序序列中插入元素。
int currentVaule = array[i];
int position = i;
for(int j=i-1;j>=0;j--){
if(array[j]>currentVaule){
array[j+1]= array[j]; // 从后往前,一一比较,如果比待插入元素大,则后移一位。
position--; // 待插入元素前移一位
}
}
array[position]=currentVaule; // 找到带插入元素的位置后,将值放入。
}
}
static void input(){
System.out.println("请输入一个数组,数字之间以英文逗号分隔:");
Scanner scanner = new Scanner(System.in);
String string = scanner.next().toString(); //读取输入,直到遇到空格或换行,并转化为字符串。
String arrayString[] = string.split(","); // 分割为字符串数组
array = new int[arrayString.length]; // 定义数组长度
for(int i=0;i<array.length;i++){
array[i] = Integer.parseInt(arrayString[i]); // 整型化
}
}
static void output() {
System.out.println("经过插入排序后,结果如下:");
for(int i=0;i<array.length;i++)
System.out.print(array[i] + " ");
}
}
</span>
本文介绍了一种简单的排序算法——插入排序,并提供了详细的Java实现代码。该算法通过将未排序的元素逐一插入已排序序列中来完成排序过程,适用于小规模数据集。其时间复杂度为O(n^2)。

被折叠的 条评论
为什么被折叠?



