插入排序最后一项未定义



我正在练习hackerrank,并希望使用插入排序处理数据结构。给定String类型的数据结构:

6
1 4 3 5 6 2

我想从索引1开始计数,所以计数索引0数组的大小,和新的行字符,我应该从2开始。我想在每个循环中记录数组下标左右移动每一步的输出。

function processData(input) {     
    function sort(input) {
        let values = input.split('n')
        values = values[1].split(' ').map(i => parseInt(i));        
        var length = values.length;
        for(var i = 1; i < length; i++) {          
            console.log('input sort', values[i])
            var temp = values[i] === undefined ? null: values[i];
            var j = i - 1;
            for(j; j >= 0 && values[j] > temp; --j) {
                values[j+1] = values[j];    
            }
            values[j+1] = temp;
            var result = values.join(" ");
            console.log(values);
       }
       // return values;
   };
};

我的输出如下。注意末尾的undefined。我对这些排序算法还是个新手,我希望有人能解释一下这是怎么来的。

input sort 4
[ 1, 4, 3, 5, 6, 2 ]
input sort 3
[ 1, 3, 4, 5, 6, 2 ]
input sort 5
[ 1, 3, 4, 5, 6, 2 ]
input sort 6
[ 1, 3, 4, 5, 6, 2 ]
input sort 2
[ 1, 2, 3, 4, 5, 6 ]
undefined

我想要一个没有undefined字符的输出。

[ 1, 4, 3, 5, 6, 2 ]
input sort 3
[ 1, 3, 4, 5, 6, 2 ]
input sort 5
[ 1, 3, 4, 5, 6, 2 ]
input sort 6
[ 1, 3, 4, 5, 6, 2 ]
input sort 2
[ 1, 2, 3, 4, 5, 6 ]

这与你的算法无关。

你看到最后那部分看起来像:

   // return values;

删除//

您在最后一行得到undefined,因为该函数没有返回值,并且您正在控制台中运行它。它不是来自您的console.log语句之一,而是来自打印执行的最后一行的结果的默认控制台行为。在本例中,最后一行是一个没有产生undefined值的函数。

最新更新