排序算法-插入排序
2021/10/25 20:39:37
本文主要是介绍排序算法-插入排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
思路:将第二个数与第一个数比较,将第二个数放在适当位置,将第三个数与前两个数比较放在适当位置
具体代码
package sort; import java.util.Arrays; public class InsertSort { public static void main(String[] args) { int[] arr = {101,34,119,1}; insertSort(arr); } //插入排序 public static void insertSort(int[] arr){ //定义待插入的数 int insertVal = arr[1]; int insertIndex = 1-1;//前面数的下标 //插入位置下标需大于0 待插入数组还没找到合适的位置 需要后移 while (insertIndex >= 0 && insertVal < arr[insertIndex]){ arr[insertIndex +1] = arr[insertIndex]; insertIndex--; } //退出循环时,说明插入位置找到 insertIndex+1 arr[insertIndex + 1] = insertVal; System.out.println("第一轮后"); System.out.println(Arrays.toString(arr)); //第二轮 //定义待插入的数 insertVal = arr[2]; insertIndex = 2-1;//前面数的下标 //插入位置下标需大于0 待插入数组还没找到合适的位置 需要后移 while (insertIndex >= 0 && insertVal < arr[insertIndex]){ arr[insertIndex +1] = arr[insertIndex]; insertIndex--; } //退出循环时,说明插入位置找到 insertIndex+1 arr[insertIndex + 1] = insertVal; System.out.println("第二轮后"); System.out.println(Arrays.toString(arr)); } }
整理后
package sort; import java.util.Arrays; public class InsertSort { public static void main(String[] args) { int[] arr = {101,34,119,1}; insertSort(arr); } //插入排序 public static void insertSort(int[] arr){ for (int i = 1; i < arr.length; i++) { //定义待插入的数 int insertVal = arr[i]; int insertIndex = i-1;//前面数的下标 //插入位置下标需大于0 待插入数组还没找到合适的位置 需要后移 while (insertIndex >= 0 && insertVal < arr[insertIndex]){ arr[insertIndex +1] = arr[insertIndex]; insertIndex--; } //退出循环时,说明插入位置找到 insertIndex+1 arr[insertIndex + 1] = insertVal; System.out.println(Arrays.toString(arr)); } } }
优化 如果顺序不需要排序,则不需要在赋值
public class InsertSort { public static void main(String[] args) { int[] arr = {101,34,119,1}; insertSort(arr); } //插入排序 public static void insertSort(int[] arr){ for (int i = 1; i < arr.length; i++) { //定义待插入的数 int insertVal = arr[i]; int insertIndex = i-1;//前面数的下标 //插入位置下标需大于0 待插入数组还没找到合适的位置 需要后移 while (insertIndex >= 0 && insertVal < arr[insertIndex]){ arr[insertIndex +1] = arr[insertIndex]; insertIndex--; } //退出循环时,说明插入位置找到 insertIndex+1 if (insertIndex +1 == i){ arr[insertIndex + 1] = insertVal; } System.out.println(Arrays.toString(arr)); } } }
插入排序问题:当顺序从小到大,最后一个数最小,则排序次数较多
这篇关于排序算法-插入排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-22项目:远程温湿度检测系统
- 2024-12-21《鸿蒙HarmonyOS应用开发从入门到精通(第2版)》简介
- 2024-12-21后台管理系统开发教程:新手入门全指南
- 2024-12-21后台开发教程:新手入门及实战指南
- 2024-12-21后台综合解决方案教程:新手入门指南
- 2024-12-21接口模块封装教程:新手必备指南
- 2024-12-21请求动作封装教程:新手必看指南
- 2024-12-21RBAC的权限教程:从入门到实践
- 2024-12-21登录鉴权实战:新手入门教程
- 2024-12-21动态权限实战入门指南