• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用java代码和伪代码实现插入排序

java 搞代码 4年前 (2022-01-09) 12次浏览 已收录 0个评论

插入排序介绍:

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

java相关免费视频教程推荐:java免费视频教程

伪代码:

INSERTION-SORT(A)	//A是数组 for j = 2 to A.lengthkey = A[j]//(将A[j]插入排序序列A[1..j-1])i = j - 1while i > 0 and A[i] > keyA[i+1] = A[i]i = i - 1A[i+1] = key

java代码:

//升序排序public void Inse<mark>本文来源gaodaimacom搞#代%码@网-</mark>rtSortAscending(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行关键字被移到的地方。

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

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

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

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

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

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

A数组此时如图所示:

第六次循环时j为6不满足循环j<A.length条件,循环退出。

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

以上就是使用java代码和伪代码实现插入排序的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用java代码和伪代码实现插入排序

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址