`
xuelianbobo
  • 浏览: 174378 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

java 简单插入排序

 
阅读更多
/***
 * 简单插入排序算法练习
 * 
 * @author bobo
 * 
 */
public class InsertSort {
	/***
	 * 插入排序的逻辑为:新建一个有序序列,从源数组中挨个挑取数组插入到有序序列的何合适位置
	 * 
	 * @param args
	 */
	public static void main(String[] args) {
		int[] a = { 1, 0, 3, 4, 2, 3, 5, 3, 6, 8, 2 };
		show(a);
		for (int i = 0; i < a.length-1; i++) {
			insertOne(a, i+1);
			show(a);
		}
		show(a);
	}

	/**
	 * 一次插入的方法
	 * 
	 * @param a
	 *            要被插入的有序序列 为提高算法的空间效率 是源数组
	 * @param i
	 *            要插入的数据的索引
	 */
	private static void insertOne(int[] a, int index) {
		// 待插入的数据的索引为i则a的有序长度应该是index
		// 第一层循环的条件中=是哨兵原则,因为index处的值有可能就放在有序序列的队尾
		for (int i = 0; i <= index; i++) {
			if (a[i] >= a[index]) {// 找到插入位置
				int tmp = a[index];// 缓存数据 防止被覆盖掉
				// 后移i到index-1这些数组的元素,腾出i的位置同时覆盖掉index的位置
				// 后移数组元素应该从后面开始 否则会出现覆盖的情况
				for (int j = index - 1; j >= i; j--) {
					a[j + 1] = a[j];
				}
				a[i] = tmp;
			}
		}
	}

	private static void show(int[] a) {
		for (int i : a) {
			System.out.print(i + "\t");
		}
		System.out.println();
	}
}

 

 

分享到:
评论

相关推荐

    java简单插入排序实例

    Java 简单插入排序实例详解 插入排序是一种简单且实用的排序算法,本文将详细介绍 Java 实现的插入排序实例,并对其进行性能分析。 一、基本概念 插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中...

    java实现插入排序

    插入排序是一种简单的排序算法,它的基本思想是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。在Java中实现插入排序,主要涉及数组操作和循环控制,我们可以从以下几个方面来理解这...

    插入排序Java代码

    ### 插入排序Java代码详解 #### 一、插入排序简介 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,...

    JAVA实现插入排序

    JAVA实现插入排序,简单演示

    java 直接插入排序

    直接插入排序是一种简单直观的排序算法,它的工作原理是通过构造一个有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。这种算法在最坏的情况下,时间复杂度为O(n^2),但在最好情况下,如...

    Java实现插入排序

    在Java中实现插入排序,我们可以按照以下步骤进行: 1. **基本思想**:将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。可以想象成每次从无序序列中取出一个元素,找到它在有序序列中...

    用java实现插入排序InsertSort

    用java实现插入排序InsertSort 用java实现插入排序InsertSort用 java实现插入排序InsertSort

    Java直接插入排序算法源码

    总的来说,Java中的直接插入排序算法是一个直观易懂的排序方法,虽然在效率上不敌更高级的排序算法,但它在理解和实现上相对简单,对于初学者来说是很好的学习材料。通过阅读和实践这个源代码,你可以深入理解排序...

    Java快速排序+简单选择排序+折半插入排序

    做了个Java Swing 图形界面,选择3中排序方法进行排序。工程用NetBeans 打开,运行Main.java文件或直接点击运行主程序,...BinSort.java(折半插入排序) QKSort.java(快速排序算法) SelectSort.java(简单选择排序)

    快速和插入排序

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

    java插入排序与合并排序

    **插入排序**是一种简单直观的排序算法,它的基本思想是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的...

    java编写的插入排序算法

    ### Java编写的插入排序算法 #### 一、插入排序算法基本思想 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在...

    插入排序的Java代码实现

    在编程领域,排序算法是数据结构与算法学习中的基础部分,而插入排序是其中一种简单但实用的排序方法。本文将详细讲解插入排序的概念、原理,并提供一个Java语言的实现示例。 插入排序是一种基本的排序算法,它的...

    插入排序法JAVA代码

    以下是一个简单的Java插入排序算法实现: ```java public class InsertionSort { public static void insertionSort(int[] array) { for (int i = 1; i ; i++) { int key = array[i]; int j = i - 1; // 将比...

    java快速排序、冒泡排序、插入排序示例

    本篇文章将详细讲解快速排序、冒泡排序和插入排序这三种常用的排序算法,并通过Java代码示例进行演示。 **快速排序** 快速排序是一种高效的排序算法,由英国计算机科学家C.A.R. Hoare于1960年提出。其基本思想是...

    直接插入排序java源码

    直接插入排序 java实现~你值得拥有~

    插入排序和归并排序的实现java

    **插入排序**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。其主要步骤如下: 1. 从第一个元素开始,该元素可以认为已经被排序。 ...

    排序算法java版,速度排行:冒泡排序、简单选择排序、直接插入排序、折半插入排序、希尔排序、堆排序、归并排序、快速排序.mht

    排序算法java版,速度排行:冒泡排序、简单选择排序、直接插入排序、折半插入排序、希尔排序、堆排序、归并排序、快速排序.mht

    java插入排序

    ### Java插入排序程序详解 #### 一、程序概述 本文将详细介绍一个Java实现的插入排序算法。插入排序是一种简单直观的排序方法,其工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到...

    Java实现插入排序.rar

    以下是一个基本的Java插入排序算法实现示例: ```java public class InsertionSort { public static void sort(int[] array) { for (int i = 1; i ; i++) { int key = array[i]; int j = i - 1; // 将大于key...

Global site tag (gtag.js) - Google Analytics