如何在沒有手動索引的情況下對Javascript中的字母等級進行排序
sorting (5)
嘗試弄清楚如何正確排列字母等級數組
['A+', 'A', 'A-', 'B+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'F']
。
標準排序功能不起作用。
我也希望在不為每個字母等級
設置手動索引的情況下
執行此
操作
。
const grades = ['B+', 'F', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'A']
grades.sort((a, b) => {
return a - b;
});
console.log(grades);
預期產量:
['A+', 'A', 'A-', 'B+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'F']
嘗試這個。
const grades = ['B+', 'A', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'F']
const sortGrades = function (grades) {
const result = grades.sort(function (a, b) {
if (a[0] < b[0]) {
return -1;
}
if (b[0] > a[0]) {
return 1;
}
if(a[0] === b[0]) {
if(a[1] && a[1] === "+") {
return -1;
}
}
return 0;
});
return result;
};
sortGrades(grades)
如果您只想堅持ASCII值:
const grades = ['B+', 'F', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'A']
grades.sort((a, b) =>
a.charCodeAt(0) === b.charCodeAt(0) // If the letters are the same
? (a.charCodeAt(1) || 44) - (b.charCodeAt(1) || 44) // Just compare the postfix
: a.charCodeAt(0) - b.charCodeAt(0) // Otherwise compare the letters
);
console.log(...grades);
ACII的
+
值為43,ASCII的
-
值為45,因此在沒有後綴的情況下可以使用44(即
,
)。
或者,使用模板文字:
const grades = ['B+', 'F', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'A']
grades.sort((a, b) =>
a.charCodeAt(0) === b.charCodeAt(0)
? `${a},`.charCodeAt(1) - `${b},`.charCodeAt(1)
: a.charCodeAt(0) - b.charCodeAt(0)
);
console.log(...grades);
很少有這樣做的方法。 一種方法是分割字符並比較各個部分。
const grades = ['B+', 'A', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'F']
const sorted = grades.sort((a, b) => {
if (a === b) return 0 // if equal nothing changes
const ap = a.split('') // separate into letter and sign
const bp = b.split('')
if (ap[0] === bp[0]) { // if first letter is the same, we have to check second
return (ap[1] === "+" || b[1] === "-") ? -1 : 1
}
return ap[0].localeCompare(b[0]) // sort by letter grade
})
console.log(sorted)
您可以分開成績,並為後綴符號取一個對象。
const grades = ['B+', 'A', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'F']
grades.sort((a, b) => {
const order = { '+': -1, '-': 1, undefined: 0 };
return a[0].localeCompare(b[0]) || order[a[1]] - order[b[1]];
});
console.log(...grades);
這是我使用簡單數學🧮的解決方案:
const grades = ['B+', 'F', 'A-', 'A+', 'B', 'B-', 'C+', 'C', 'C-', 'D+', 'D', 'D-', 'A']
const getCounter = (letter) => {
// Making simple math to sort it out
let letterCounter = letter.charCodeAt(0) * 10;
if(letter[1] === "+"){
letterCounter -= 1;
}
else if(letter[1] === "-"){
letterCounter += 1;
}
return letterCounter;
}
grades.sort((a, b) => {
return getCounter(a) - getCounter(b);
});
console.log(grades)
// Print => ['A+','A','A-','B+','B','B-','C+','C','C-','D+','D','D-','F']