算法
// arr是传入的数组
function groupByDesc(arr) {
const [...zhCN] = '阿八嚓哒妸发旮哈讥咔垃痳拏噢妑七呥扨它穵夕丫杂'
const [...EN] = 'abcdefghijklmnopqrstuvwxyz'
// 中文在i、u、v下没有对应的汉字
const [...desc] = 'abcdefghjklmnopqrstwxyz'
const isChinese = /[\u4e00-\u9fa5]+/
const isSpecial = /[0-9*#@!%$&(),.+-]+/
const hashMap = {}
function findIndex(obj) {
for (let i = 0; i < isChinese.test(obj) ? zhCN.length : EN.length; i++) {
if (obj.localeCompare(isChinese.test(obj) ? zhCN[i] : EN[i]) <= 0) {
return i >= 1 ? i - 1 : 0
}
}
return 22
}
arr.forEach(item => {
let hashCode = isChinese.test(item) ? desc[findIndex(item)] : EN[findIndex(item)]
isSpecial.test(item) ? hashCode = '#' : ''
if (!hashMap[hashCode]) {
hashMap[hashCode] = []
}
hashMap[hashCode].push(item)
})
return hashMap
}
使用案例
function groupByDesc(arr) {
const [...zhCN] = '阿八嚓哒妸发旮哈讥咔垃痳拏噢妑七呥扨它穵夕丫杂'
const [...EN] = 'abcdefghijklmnopqrstuvwxyz'
// 中文在i、u、v下没有对应的汉字
const [...desc] = 'abcdefghjklmnopqrstwxyz'
const isChinese = /[\u4e00-\u9fa5]+/
const isSpecial = /[0-9*#@!%$&(),.+-]+/
const hashMap = {}
function findIndex(obj) {
for (let i = 0; i < isChinese.test(obj) ? zhCN.length : EN.length; i++) {
if (obj.localeCompare(isChinese.test(obj) ? zhCN[i] : EN[i]) <= 0) {
return i >= 1 ? i - 1 : 0
}
}
return 22
}
arr.forEach(item => {
let hashCode = isChinese.test(item) ? desc[findIndex(item)] : EN[findIndex(item)]
isSpecial.test(item) ? hashCode = '#' : ''
if (!hashMap[hashCode]) {
hashMap[hashCode] = []
}
hashMap[hashCode].push(item)
})
return hashMap
}
var arr = ["北京", "天津", "上海", "重庆", "新疆", "西藏", "宁夏", "内蒙古",
"广西", "黑龙江", "吉林", "辽宁", "河北", "山东", "江苏", "安徽",
"浙江", "福建", "广东", "海南", "云南", "贵州", "四川", "湖南",
"湖北", "河南", "山西", "陕西", "甘肃", "青海", "江西", "台湾", "香港", "澳门",'CBA','NBA','@','#','&'
]
console.log(groupByDesc(arr))
运行结果:
不仅支持中文,还支持数字,特殊字符