`
543089122
  • 浏览: 153820 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

简单_插入排序(Insertion-sort)

 
阅读更多
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;
				}
			}
		}
	}
}

分享到:
评论

相关推荐

    基于python的排序算法-插入排序Insertion Sort

    **插入排序(Insertion Sort)**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到...

    JavaScript 数据结构与算法:气泡排序 Bubble Sort、插入排序 Insertion Sort 实作与分析 - 彭彭直播 at 2020/10/13

    JavaScript_資料結構與演算法_氣泡排序_Bubble_Sort、插入排序_Insertion_Sort_實作與分析_-

    Insertion sorting,插入排序,c++

    插入排序(Insertion Sort)是一种简单直观的比较排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用...

    插入排序的设计实现分析比较.rar_C# 插入_插入排序

    插入排序是一种简单直观的排序算法,它的工作原理类似于人们整理扑克牌的过程。在未排序的序列中,每次取出一个元素,找到它在已排序序列中的合适位置,并将它插入进去。这个过程会一直持续到所有元素都在其正确的...

    实验4-插入排序、快速排序、选择排序.rar_C语言_北京理工大学_插入排序实验_数据结构

    **插入排序(Insertion Sort)** 插入排序是一种简单直观的排序算法,它的工作原理类似于人们整理扑克牌的过程。算法首先假设数组的第一个元素已经排好序,然后从第二个元素开始,依次将每个元素插入到已排序的部分...

    C语言版的排序方法---插入排序.docx

    - 在提供的代码中,`InsertionSort`函数实现了插入排序。函数接受一个整型数组`nData`和它的元素个数`nNum`作为参数。 - `for`循环从第二个元素开始遍历数组,因为第一个元素默认已经排序。 - 内部的`for`循环...

    图解插入排序-直接插入排序算法(straight insertion sort)

    图解插入排序——直接插入排序算法(straight insertion sort)

    经典算法的C#源码实现

    经典排序算法 - 插入排序Insertion sort 经典排序算法 - 基数排序Radix sort 经典排序算法 - 鸽巢排序Pigeonhole sort 经典排序算法 - 归并排序Merge sort 经典排序算法 - 冒泡排序Bubble sort 经典排序算法 - ...

    paixusuanfa.rar_插入排序

    **插入排序(Insertion Sort)** 插入排序是一种简单直观的排序算法,它的工作原理类似于我们日常整理扑克牌的过程。算法分为两步: 1. **遍历待排序序列**:从第二个元素开始,逐个遍历。 2. **将元素插入到已排序...

    选择排序-插入排序-快速排序-冒泡排序

    2. **插入排序(Insertion Sort)** - 插入排序的工作原理类似于人们整理扑克牌的过程,将未排序的元素逐个插入到已排序的部分,确保每次插入后保持已排序部分的顺序。 - C语言实现插入排序时,通常使用两个指针,...

    排序算法-基于C语言实现的排序算法之InsertionSort实现.zip

    插入排序(Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O...

    c代码-插入排序-- https://www.runoob.com/data-structures/insertion-sort.html http://c.biancheng.net/view/525.html

    **插入排序**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。这种算法对大数据集的效率较低,但对于小规模数据或者部分有序的数据,...

    sort-algorithm_java.rar_sort_快速排序

    1. 插入排序(Insertion Sort): 插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。它的平均时间复杂度为O(n^2),但在接近...

    排序算法-插入排序

    从提供的`InsertionSort.cpp`文件中,我们可以期待看到一个用C++实现的插入排序。通常,C++代码会包含一个名为`insertionSort`的函数,该函数接受一个整数数组和数组大小作为参数,然后对数组进行插入排序。 通过...

    insertion-sort-js:javascript中的插入排序示例

    插入排序是一种简单的排序算法,它的工作原理类似于人们如何手动整理一叠扑克牌。在JavaScript中实现插入排序,我们可以深入理解其基本逻辑,并通过实例来掌握它。以下是对这个"insertion-sort-js"项目的详细解析。 ...

    Sort_show.rar_Hill-climbing_show_sortshowdemo_排序算法

    插入排序(Insertion Sort)** 插入排序是一种简单的排序方法,它将待排序的元素逐个插入到已排序的部分,类似于打扑克时整理手牌的过程。其平均和最坏时间复杂度同样为O(n^2),但在处理部分有序的数据时效率较高。...

    直接插入排序(Insertion Sort).md

    直接插入排序(Insertion Sort)是一种简单直观的排序算法,其基本思想是将数据分为已排序部分和未排序部分。在每次遍历未排序部分的数据时,将这个数据插入到合适的位置,使得已排序部分仍然保持有序。

    经典排序算法源代码-插入排序-选择排序-冒泡排序

    1. **插入排序(Insertion Sort)** - 插入排序是一种简单直观的排序算法,它的工作原理类似于我们日常整理扑克牌的过程。初始时,数组可以看作是未排序序列,已排序序列为空。每次从未排序序列中取出一个元素,...

Global site tag (gtag.js) - Google Analytics