java插入排序_程序员:算法导论,插入排序,伪代码和Java实现

插入排序

我们首先介绍插入排序。相信大部分人都打过扑克牌,许多人喜欢发一张牌就拿一张牌到手上,并且按顺序来放好牌。开始时我们左手为空,牌在桌子上。然后我们每次从桌子上拿走一张牌并将它插入左手中的位置。为了找到一张牌的正确位置,我们从右到左将它与已在手中的每张牌进行比较。

伪代码:

INSERTION-SORT(A) //A是数组

for j = 2 to A.length

key = A[j]

//(将A[j]插入排序序列A[1..j-1])

i = j - 1

while i > 0 and A[i] > key

A[i+1] = A[i]

i = i - 1

A[i+1] = key

Java代码实现:

//升序排序

public void InsertSortAscending(int[] A){

for(int j = 1;j < A.length;j++){

int key = A[j];

//将A[j]插入排序序列A[1..j-1]

int i = j - 1;

while(i >= 0 && A[i] > key){

A[j+1] = A[i];

i = i - 1;

}

A[i+1] = key;

}

}

下面我们来看一下插入排序的运行步骤

用数组A[2,4,7,1,3,6]来举例子

每次for循环中,黄色的长方形是A[j]的值,在第7行的while循环中将它与其左边的蓝色的长方形中的值进行比较。蓝色的箭头指出数组在第8行向右移动一个位置,黄色的箭头指出第11行关键字被移到的地方。

第一次循环:如下图所示

43f7292eea544143463bb640354c7ab9.png

第二次循环:如下图所示

73ce353cdce07bb74019d864f33bb41c.png

注意:这里A[2]大于A[1],因为A[1]肯定是大于A[0]的所以没必要在比较A[2]与A[1]的大小。while循环因不满足条件会退出。

第三次循环:如下图所示

67d705e8f46920a236e28786a112e7de.png

第四次循环:如下图所示

5933f5ea1fc8a825f24b738ab83def88.png

第五次循环:如下图所示

e88c9a1627c6b1d3ff3af2f005c9504b.png

A数组此时如图所示:

347dfc4ac5a5d042fa70214bf4189c7d.png


第六次循环时j为6不满足循环j

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值