热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java怎么改写伪代码_使用java代码和伪代码实现插入排序

插入排序介绍:相信大部分人都打过扑克牌,许多人喜欢发一张牌就拿一张牌到手上,并且按顺序来放好牌。开始时我们左手为空,牌在桌子

cf999fdf3243adf880d23195d744fcb3.png

插入排序介绍:

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

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

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行关键字被移到的地方。

第一次循环:如下图所示:

ee6cf18a08de4933601b51a244b7e0db.png

第二次循环:如下图所示:

9900e2a2d499b4a8364da7555f9fd7d0.png

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

第三次循环:如下图所示:

79d6b04ff8fee8c5730cd9f1b1b51417.png

第四次循环:如下图所示:

c3bf226b624db8e89daadecc9ea4799b.png

第五次循环:如下图所示:

32339c1de384a0b3bbdaccf39afb49c7.png

A数组此时如图所示:

4c7fb54ca3d9e67431172bee2ca315eb.png

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

推荐java相关文章教程:java入门程序



推荐阅读
author-avatar
茶茶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有