2016-07-05 70 views
0

我试图根据数字中存在的数字来排序数组中的字符串,即。 'h2ello f3ere b1ow'应该返回一个['b1ow','h2ello','f3ere']的数组。下面的代码适用于两个元素(h2ello和b1ow),但不添加第三个时。有没有人有一个想法,为什么这是?根据字符串中的数字排序数组中的字符串

function order(words){ 
    var sentence = []; 
    words = words.split(" "); 
for (var i=0;i<words.length;i++){ 
    for (var m=0;m<words[i].length;m++){ 
    if (!isNaN(parseFloat(words[i][m])) && isFinite(words[i][m])){ 
    var idx = words[i][m]; 
     sentence.splice(idx, 0, words[i]); 
    } 
    } 
} 
console.log(sentence); 
} 

order('h2ello f3ere b1ow'); 

回答

0

如果检查拼接文档:Array splice,你会看到,如果指数大于数组的长度越长,它会被设置为数组的长度。所以它只是在推动而不是设置你想要的索引。一种解决方案可以手动设置它:

sentence[idx-1] = words[i] 

根据你的需要,你也可以简化您的功能相当多:

function order(words){ 
    words = words.split(" ").sort(function(a,b){ 
    return a.match(/\d/) - b.match(/\d/) // get first digit and compare them 
    }) 
console.log(words); 
} 
2

最简单的将是直接的排序阵列,无需拼接其他地方未知的地方(循环中)。

本提案使用Array#sort,它带有一个回调,该回调查找要排序的某个小数。

var array = 'h2ello f3ere b1ow'.split(' '); 
 

 
array.sort(function (a, b) { 
 
    return a.match(/\d+/) - b.match(/\d+/); 
 
}); 
 

 
console.log(array);

0

我不知道它有更好的表现。顺便说一句,我比较每个正则表达式的匹配少一个。

var sorted = 'h2ello f3ere b1ow'.split(' ') 
 
    .map(w => ({ key: w.match(/\d+/)[0], word: w })) 
 
    .sort((a, b) => a.key - b.key) 
 
    .map(o => o.word).join(' '); 
 

 
console.log(sorted);