我们需要编写一个JavaScript函数,该函数接受两个数字数组,第二个数组的大小小于第一个。
我们的函数应该是第一个数组的排序版本(按升序排列),但是将两个数组中共有的所有元素放在最前面。
例如-如果两个数组是-
const arr1 = [5, 4, 3, 2, 1]; const arr2 = [2, 3];
那么输出应该是-
const output = [2, 3, 1, 4, 5];
以下是代码-
const arr1 = [5, 4, 3, 2, 1];
const arr2 = [2, 3];
//辅助功能
const sorter = (a, b, arr) => {
if(arr.includes(a)){
return -1;
};
if(arr.includes(b)){
return 1;
};
return a - b;
};
const prioritySort = (arr1, arr2) => {
arr1.sort((a, b) => sorter(a, b, arr2));
};
prioritySort(arr1, arr2);
console.log(arr1);输出结果
以下是控制台中的输出-
[ 2, 3, 1, 4, 5 ]