假设我们有一个用逗号分隔的单词字符串,如下所示:
const str = 'JAY, ROB';
我们需要编写一个包含一个这样的字符串的JavaScript函数。该函数可以从字符串中的单词创建一个新单词,其中前一个字母始终大于下一个字母(例如,A大于B)
例如,在上面的字符串中,我们要比较JAY的第一个字母和ROB的第一个字母。
由于与R相比J排在第一位,因此新单词的第一个字母为J。相比之下,第二个单词由于A在R之前成为第二个字母,因此第三个字母类似地成为R。
因此,最后一个字就是“ JAROBY”
请注意,在这个示例中,我们只用了两个单词组成的字符串,但是我们要求编写一个也可以使用两个以上单词的解决方案。
为此的代码将是-
const str = `JAY,ROB,APPLE,AAKO`; const specialSort = (str = '') => { let len = str.replace(/,/g, "").length; const sorter = (str, b) => { if(str === "" || str === null) return 1; if(b === "" || b === null) return −1; if(str === b) return 0; return str < b ? −1 : 1; }; let res = ""; let sorted = str.split(",").sort(sorter); while (res.length < len){ res += sorted[0][0]; sorted[0] = sorted[0].slice(1); sorted = sorted.sort(sorter); } return res; }; console.log(specialSort(str));
输出结果
控制台中的输出将是-
AAAJAKOPPLEROBY