网站首页 > java教程 正文
一、插入排序
思想:每步将一个待排序的记录,按其顺序码大小插入到前面已经排序的字序列的合适位置,直到全部插入排序完为止。
关键问题:在前面已经排好序的序列中找到合适的插入位置。
方法:直接插入排序、二分插入排序、希尔排序
二、直接插入排序
基本思想:每步将一个待排序的记录,按其顺序码大小插入到前面已经排序的字序列的合适位置(从后向前找到合适位置后),直到全部插入排序完为止。
java实现
public class ZhiJieChaRu {
/**
* 直接插入排序第一版
* @param a
* @return
*/
public static int[] sort1(int[] a) {
//假设第一个记录为已经待排序好的记录,那么要比较a.length-1个记录,所以外层循环是a.length-1次
//这里可以直接i=1从第二位开始处理也一样
for(int i=1;i<a.length;i++) {
//跟前面已排序的记录做对比,找到合适的位置,建议从后往前面比,若是比最后一位小,则向前移动一位,否则就直接找到该位置
for(int j=i-1;j>=0;j--) {
//如果当前待排序的数比这一个排序的数大,则跳出循环,否则交换位置
if(a[j+1]>a[j]) {
break;
}else {
//这种每次比较后都马上移动,每次都定义临时变量,我们其实可以找到位置,最后再出入一次即可
int temp = a[j+1];
a[j+1]=a[j];
a[j]=temp;
}
}
}
return a;
}
/**
* 插入排序改进版,找到位置最后才插入
* @param a
* @return
*/
public static int[] sort2(int[] a) {
//假设第一个记录为已经待排序好的记录,那么要比较a.length-1个记录,所以外层循环是a.length-1次
//这里可以直接i=1从第二位开始处理也一样
for(int i=1;i<a.length;i++) {
//缓存待排序的记录
int temp = a[i];
int j;//这个是待插入的位置-1
//跟前面已排序的记录做对比,找到合适的位置,建议从后往前面比,若是比最后一位小,则向前移动一位,否则就直接找到该位置
for(j=i-1;j>=0;j--) {
//如果当前待排序的数比这一个排序的数大,则跳出循环,否则交换位置
if(temp>a[j]) {
break;
}else {
//把当前记录往后面移动一位
a[j+1]=a[j];
}
}
a[j+1]=temp;
}
return a;
}
public static void main(String[] args) {
int[] a = {49,38,65,97,76,13,27,49,78,34,12,64,1};
System.out.print("排序之前:");
for (int i = 0; i < a.length; i++) {
System.out.print(a[i]+" ");
}
System.out.println();
System.out.print("sort1:");
int[] a1 = sort1(a);
int[] a2 = sort2(a);
for (int i = 0; i < a1.length; i++) {
System.out.print(a1[i]+" ");
}
System.out.println();
System.out.print("sort2:");
for (int i = 0; i < a2.length; i++) {
System.out.print(a2[i]+" ");
}
}
}
上面有两种实现方法,第二种sort2比较好,不用每次都新建temp;
- 上一篇: 十大经典排序算法最强总结(含JAVA代码实现)
- 下一篇: java桶式排序算法(桶排序代码)
猜你喜欢
- 2024-11-03 java桶式排序算法(桶排序代码)
- 2024-11-03 十大经典排序算法最强总结(含JAVA代码实现)
- 2024-11-03 JAVA从零开始之排序算法(spicyChicken盘点)
- 2024-11-03 排序算法实现-堆排序(Java版本)(堆排序实现代码)
- 2024-11-03 JAVA十大排序算法之基数排序详解(java的排序)
- 2024-11-03 十大经典《排序算法》你还记得多少?
- 2024-11-03 Java排序算法——选择排序(java的选择排序)
- 2024-11-03 java实现10种排序算法(java十大排序算法)
- 2024-11-03 JAVA十大经典排序算法(java常见排序算法)
- 2024-11-03 常用排序算法总结(常用排序算法总结)
你 发表评论:
欢迎- 05-02Go 中的 channel 与 Java BlockingQueue 的本质区别
- 05-02处理线上RabbitMQ队列阻塞(rabbitmq队列状态)
- 05-02实现延迟队列,这些你知道吗?(延迟队列 kafka)
- 05-02学无止境:AQS阻塞队列和条件队列是如何使用的?
- 05-02京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?
- 05-02阻塞队列ArrayBlockingQueue的实现原理浅析
- 05-02高性能队列:Java Concurrent包中的BlockingQueue
- 05-02不允许还有Java程序员不了解BlockingQueue阻塞队列的实现原理
- 最近发表
-
- Go 中的 channel 与 Java BlockingQueue 的本质区别
- 处理线上RabbitMQ队列阻塞(rabbitmq队列状态)
- 实现延迟队列,这些你知道吗?(延迟队列 kafka)
- 学无止境:AQS阻塞队列和条件队列是如何使用的?
- 京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?
- 阻塞队列ArrayBlockingQueue的实现原理浅析
- 高性能队列:Java Concurrent包中的BlockingQueue
- 不允许还有Java程序员不了解BlockingQueue阻塞队列的实现原理
- JAVA并发之BlockingQueue(阻塞队列)
- dify案例分享-API文档生成接口代码
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)