算法之插入排序(java和python实现)

1、插入排序是什么

其实跟扑克牌一样,就是一个整牌的过程,将牌依次去排序的一个过程,而生活中我们可能会整理牌、书籍、银行卡等等,而在代码中我们整理的是数据(这次是一个序列)

2、Java实现

复制代码
import java.util.Arrays;
public class Main {
    public static void main(String[] args) {
        int [] a = {2,3,4,5,6,78,9,0,9};
        int i ;
        for(int y = 2;y<a.length;y++){//循环次数
            int home = a[y];//做一个中间值
            i=y-1;
            while (i>(-1) && a[i]>home){//判断条件
                a[i+1] = a[i];//进行一个插入操作
                i = i-1;
                a[i+1] = home;
            }
        }
        System.out.println(Arrays.toString(a));//输出
    }
}

3、python实现

复制代码
a = [1, 2, 3, 5, 6, 7, 9, 3, 10, 56, 3]

for i in range(len(a)):  # 控制次数
    key = a[i]  # 循环不变式
    j = i - 1
    while j >= 0 and a[j] > key:  # 控制条件
        a[j + 1] = a[j]  # 启动插入排序
        j = j - 1
        a[j + 1] = key

print(a)  # 输出结果来判断是否正确

这里的代码是进行一个从小到大的排序

我将会把python代码更改为从大到小,如下:

复制代码
a = [1, 2, 3, 5, 6, 7, 9, 3, 10, 56, 3]

for i in range(len(a)):  # 控制次数
    key = a[i]  # 循环不变式
    j = i - 1
    while j >= 0 and a[j] < key:  # 控制条件
        a[j + 1] = a[j]  # 启动插入排序
        j = j - 1
        a[j + 1] = key

print(a)  # 输出结果来判断是否正确
相关推荐
customer0843 分钟前
【开源免费】基于SpringBoot+Vue.JS校园社团信息管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·java-ee·开源
humors2211 小时前
java实现excel导入参考资料合集
java·前端·后端·wps·导出·导入·office
篱笆院的狗1 小时前
1、Java中的序列化和反序列化是什么?
java·开发语言
等一场春雨1 小时前
Spring Boot 3 文件上传、多文件上传、大文件分片上传、文件流处理以及批量操作
java·spring boot·后端
骑着王八撵玉兔2 小时前
【非关系型数据库Redis 】 入门
java·数据库·spring boot·redis·后端·缓存·nosql
小七蒙恩2 小时前
java 上传txt json等类型文件解析后返回给前端
java·前端·json
懒大王爱吃狼2 小时前
Python 向量检索库Faiss使用
开发语言·python·自动化·python基础·python教程
郭老师的小迷弟雅思莫了3 小时前
【JAVA高级篇教学】第六篇:Springboot实现WebSocket
java·spring boot·websocket
KeyPan3 小时前
【视觉SLAM:八、后端Ⅰ】
人工智能·数码相机·算法·机器学习·计算机视觉
Jackilina_Stone3 小时前
【论文阅读笔记】SCI算法与代码 | 低照度图像增强 | 2022.4.21
论文阅读·人工智能·笔记·python·算法·计算机视觉