【算法题】字符统计及重排(js)

2023-12-13 07:20:24

在这里插入图片描述
在这里插入图片描述

解法:

const str = "xyxyXX";
const str1 = "abababb";
function solution(str) {
  const strArr = str.split("").sort((a, b) => a - b);
  const map = new Map();
  for (let i = 0; i < strArr.length; i++) {
    if (map.has(strArr[i])) {
      map.set(strArr[i], map.get(strArr[i]) + 1);
    } else {
      map.set(strArr[i], 1);
    }
  }
  let arr = [];
  for (let [key, value] of map) {
    arr.push(`${key}:${value}`);
  }
  return arr.sort((a, b) => b.split(":")[1] - a.split(":")[1]).join(";");
}

console.log(solution(str1));
/* 
xyxyXX  => x:2;y:2;X:2
abababb => b4;a:3
 */

文章来源:https://blog.csdn.net/qq_43682422/article/details/134943008
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。