算法之插入排序(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)  # 输出结果来判断是否正确
相关推荐
其实防守也摸鱼8 分钟前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
MediaTea1 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z1 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue1 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
callJJ1 小时前
Spring Data Redis 两种编程模型详解:同步 vs 响应式
java·spring boot·redis·python·spring
小郑加油1 小时前
python学习Day12:pandas安装与实际运用
开发语言·python·学习
AC赳赳老秦1 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
.柒宇.1 小时前
AI掘金头条项目-K8s部署实战教程
python·云原生·容器·kubernetes·fastapi
风筝在晴天搁浅2 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
观北海2 小时前
从 Sim2Sim 到 Sim2Real:以 ONNX 为核心的机器人策略实机落地全指南
python·机器人