package sunfa.sort;
import java.util.Arrays;
import java.util.Random;
public class InsertionSort {
public static void main(String[] args) {
Random ran = new Random();
int[] a = new int[10];
for (int i = 0; i < a.length; i++) {
a[i] = ran.nextInt(100);
}
System.out.println(Arrays.toString(a));
insertionSort(a);
System.out.println(Arrays.toString(a));
Arrays.sort(a);
System.out.println(Arrays.toString(a));
}
/**
* 插入排序算法(insertion-sort)适合少量数据排序的算法
* @param a
*/
public static void insertionSort(int[] a) {
for (int i = 1; i < a.length; i++) {
int key = a[i];//保存刚才摸到的那张牌
for (int k = 0; k < i; k++) {//0-i 为左手拿着的牌的集合
if (a[i] < a[k]) {//将刚才抓到的那张牌依次和左手的牌进行比较,目的是为了找到它应该放的位置
for (int j = i - 1; j >= k; j--) {
a[j + 1] = a[j];//找到位置之后将该位置后面的牌的位置后移
}
a[k] = key;//插入牌到适合的位置
break;
}
}
}
}
}
分享到:
相关推荐
**插入排序(Insertion Sort)**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到...
JavaScript_資料結構與演算法_氣泡排序_Bubble_Sort、插入排序_Insertion_Sort_實作與分析_-
插入排序(Insertion Sort)是一种简单直观的比较排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用...
插入排序是一种简单直观的排序算法,它的工作原理类似于人们整理扑克牌的过程。在未排序的序列中,每次取出一个元素,找到它在已排序序列中的合适位置,并将它插入进去。这个过程会一直持续到所有元素都在其正确的...
**插入排序(Insertion Sort)** 插入排序是一种简单直观的排序算法,它的工作原理类似于人们整理扑克牌的过程。算法首先假设数组的第一个元素已经排好序,然后从第二个元素开始,依次将每个元素插入到已排序的部分...
- 在提供的代码中,`InsertionSort`函数实现了插入排序。函数接受一个整型数组`nData`和它的元素个数`nNum`作为参数。 - `for`循环从第二个元素开始遍历数组,因为第一个元素默认已经排序。 - 内部的`for`循环...
图解插入排序——直接插入排序算法(straight insertion sort)
经典排序算法 - 插入排序Insertion sort 经典排序算法 - 基数排序Radix sort 经典排序算法 - 鸽巢排序Pigeonhole sort 经典排序算法 - 归并排序Merge sort 经典排序算法 - 冒泡排序Bubble sort 经典排序算法 - ...
**插入排序(Insertion Sort)** 插入排序是一种简单直观的排序算法,它的工作原理类似于我们日常整理扑克牌的过程。算法分为两步: 1. **遍历待排序序列**:从第二个元素开始,逐个遍历。 2. **将元素插入到已排序...
2. **插入排序(Insertion Sort)** - 插入排序的工作原理类似于人们整理扑克牌的过程,将未排序的元素逐个插入到已排序的部分,确保每次插入后保持已排序部分的顺序。 - C语言实现插入排序时,通常使用两个指针,...
插入排序(Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O...
**插入排序**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。这种算法对大数据集的效率较低,但对于小规模数据或者部分有序的数据,...
1. 插入排序(Insertion Sort): 插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。它的平均时间复杂度为O(n^2),但在接近...
从提供的`InsertionSort.cpp`文件中,我们可以期待看到一个用C++实现的插入排序。通常,C++代码会包含一个名为`insertionSort`的函数,该函数接受一个整数数组和数组大小作为参数,然后对数组进行插入排序。 通过...
插入排序是一种简单的排序算法,它的工作原理类似于人们如何手动整理一叠扑克牌。在JavaScript中实现插入排序,我们可以深入理解其基本逻辑,并通过实例来掌握它。以下是对这个"insertion-sort-js"项目的详细解析。 ...
插入排序(Insertion Sort)** 插入排序是一种简单的排序方法,它将待排序的元素逐个插入到已排序的部分,类似于打扑克时整理手牌的过程。其平均和最坏时间复杂度同样为O(n^2),但在处理部分有序的数据时效率较高。...
直接插入排序(Insertion Sort)是一种简单直观的排序算法,其基本思想是将数据分为已排序部分和未排序部分。在每次遍历未排序部分的数据时,将这个数据插入到合适的位置,使得已排序部分仍然保持有序。
1. **插入排序(Insertion Sort)** - 插入排序是一种简单直观的排序算法,它的工作原理类似于我们日常整理扑克牌的过程。初始时,数组可以看作是未排序序列,已排序序列为空。每次从未排序序列中取出一个元素,...