最近看编程之美,发现排序算法是其基础。若排序算法掌握的不牢固,看起来很是头疼,于是又从新看了一遍排序算法。在网上查了一下,发现有很多,但是纸上得来终觉浅,自己根据算法思想做了一遍。插入排序算法思想如下:
- 从第一个元素开始,该元素可以认为已经被排序
- 取出下一个元素,在已经排序的元素序列中从后向前扫描
- 如果该元素(已排序)大于新元素,将该元素移到下一位置
- 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置
- 将新元素插入到该位置后
- 重复步骤2~5
具体代码如下:
public class Insertarray {
public static void main(String[] args){
int[] array={1,4,7,2,5,8,3,6,9};
int temp ;
for(int i=1;i<array.length;i++){
temp = array[i];//取出待排序元素
int j=i;//指向当前待排序元素
//从后向前遍历,看前面的元素是否大于当前待排序元素,如果大于则把当前元素后移
while((j>0)&&(array[j-1]>temp)){
array[j]=array[j-1];
j--;
}
//不大于则是其插入位置
array[j]=temp;
}
for(int i=0;i<array.length;i++){
System.out.print(array[i]+" ");
}
}
}
相关推荐
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编写的插入排序算法 #### 一、插入排序算法基本思想 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在...
### 插入排序Java代码详解 #### 一、插入排序简介 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,...
本文将深入探讨两种常见的排序算法:插入排序和合并排序,并基于一个长度为200000的数组进行性能比较。 **插入排序**是一种简单直观的排序算法,它的基本思想是通过构建有序序列,对于未排序数据,在已排序序列中从...
这段代码首先定义了一个`sort`方法,它接受一个整型数组作为参数,然后使用插入排序算法对其进行排序。`main`方法中创建了一个未排序的数组并调用`sort`方法进行排序,最后打印排序前后的数组以验证结果。 5. **...
在 Java 中,插入排序算法可以通过以下代码实现: ```java public class Insertion { public static void insertionSort(int[] arr) { int n = arr.length; for (int i = 1; i ; i++) { int key = arr[i]; int ...
下面是基于Java的插入排序算法实现: ```java public class InsertSort { public static void insertSort(int[] arr) { int n = arr.length; for (int i = 1; i ; i++) { // 将arr[i]插入到已排序的子数组arr...
在编程领域,排序算法是数据结构与算法学习中的重要组成部分,尤其在Java中,掌握各种排序算法对于优化程序性能至关重要。以下将详细讲解标题和描述中提到的五种排序算法:选择排序、插入排序、自顶向上合并排序、...
插入排序算法java代码,望对大家有帮助
下面我们将详细探讨Java实现的直接插入排序算法: 1. **算法步骤** - 初始化:设置一个空的有序序列,将第一个元素视为已排序。 - 遍历:从第二个元素开始遍历数组,将其称为当前元素。 - 比较:将当前元素与已...
java排序算法java排序算法插入选择冒泡java排序算法插入选择冒泡
本文将详细探讨标题所提及的几种排序算法:合并排序、插入排序、希尔排序、快速排序、冒泡排序以及桶排序,并结合Java语言的实现进行解析。 1. **合并排序(Merge Sort)**: 合并排序是一种基于分治策略的排序算法...
### Java插入排序程序详解 #### 一、程序概述 本文将详细介绍一个Java实现的插入排序算法。插入排序是一种简单直观的排序方法,其工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到...
在本文中,我们将深入探讨Java编程中的三种基本排序算法:冒泡排序、插入排序和堆排序。这些排序算法是计算机科学中的基础知识,尤其对于初学者来说,理解和实现它们至关重要。我们将详细讲解每种排序算法的工作原理...
在编程领域,排序算法是数据结构与算法学习中的基础部分,而插入排序是其中一种简单但实用的排序方法。本文将详细讲解插入排序的概念、原理,并提供一个Java语言的实现示例。 插入排序是一种基本的排序算法,它的...
以下是一个基本的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...
做了个Java Swing 图形界面,选择3中排序方法进行排序。工程用NetBeans 打开,运行Main.java文件或直接点击运行主程序,...BinSort.java(折半插入排序) QKSort.java(快速排序算法) SelectSort.java(简单选择排序)