插入排序 插入排序是这样实现的: 首先新建一个空列表,用于保存已排序的有序数列(我们称之为"有序列表")。 从原数列中取出一个数,将其插入"有序列表"中,使其仍旧保持有序状态。 重复2号步骤,直至原数列为空。 插入排序的平均时间复杂度为平方级的,效率不高,但是容易实现。它借助了"逐步扩大成果"的思想,使有序列表的长度逐渐增加,直至其长度等于原列表的长度。 (引自百度百科) javascript代码 复制代码 代码如下: <BR>var org = [5, 4, 3, 2, 1, 6, 7, 9, 8, 10]; <BR>var tempArr = new Array(); <BR>for (var i = 0; i < org.length; i++) { <BR>if (i == 0) { <BR>tempArr[0] = org[0]; //把第一个元素放到新序列 <BR>} else { <BR>for (var j = 0; j < tempArr.length; j++) { <BR>if (org[i] > tempArr[j]) { <BR>//如果是新序列的最后一个元素,则插入 <BR>if (j == tempArr.length - 1) { <BR>tempArr[j + 1] = org[i]; <BR>break; <BR>} else {//如果不是最后一个元素,则往后移动 <BR>continue; <BR>} <BR>} else { <BR>//移动新序列、然后插入 <BR>for (var k = tempArr.length - 1; k >= j; k--) { <BR>tempArr[k + 1] = tempArr[k]; <BR>} <BR>tempArr[j] = org[i]; <BR>break; <BR>} <BR>} <BR>} <BR>} <BR>alert(tempArr); <BR>