您好,欢迎访问一九零五行业门户网

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

插入排序介绍:
相信大部分人都打过扑克牌,许多人喜欢发一张牌就拿一张牌到手上,并且按顺序来放好牌。开始时我们左手为空,牌在桌子上。然后我们每次从桌子上拿走一张牌并将它插入左手中的位置。为了找到一张牌的正确位置,我们从右到左将它与已在手中的每张牌进行比较。
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 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行关键字被移到的地方。
第一次循环:如下图所示:
第二次循环:如下图所示:
注意:这里a[2]大于a[1],因为a[1]肯定是大于a[0]的所以没必要在比较a[2]与a[1]的大小。while循环因不满足条件会退出。
第三次循环:如下图所示:
第四次循环:如下图所示:
第五次循环:如下图所示:
a数组此时如图所示:
第六次循环时j为6不满足循环j 推荐java相关文章教程:java入门程序
以上就是使用java代码和伪代码实现插入排序的详细内容。
其它类似信息

推荐信息