当前位置: 首页 > news >正文

算法16(力扣451)——根据字符出现频率排序

1、问题

  给定一个字符串 s ,根据字符出现的 频率 对其进行 降序排序 。一个字符出现的频率 是它出现在字符串中的次数, 返回 已排序的字符串。如果有多个答案,返回其中任何一个。

2、示例

(1)

           输入: s = "tree"

            输出: "eert"

            解释: 'e'出现两次,'r'和't'都只出现一次。

            因此'e'必须出现在'r'和't'之前。此外,"eetr"也是一个有效的答案。

(2)

            输入: s = "cccaaa"

            输出: "cccaaa"

            解释: 'c'和'a'都出现三次。此外,"aaaccc"也是有效的答案。

            注意"cacaca"是不正确的,因为相同的字母必须放在一起。

(3)

            输入: s = "Aabb"

            输出: "bbAa"

            解释: 此外,"bbaA"也是一个有效的答案,但"Aabb"是不正确的。

            注意'A'和'a'被认为是两种不同的字符。

3、实现思路

       将字符串分割成数组,然后利用map统计频次,通过sort排序,最后将排好序的数组通过join拼接为字符串

4、具体步骤

(1)  将字符串分割成数组

(2)统计频次

(3)将map数组按照键值的形式存到数组

(4)将键通过repeat重复值次,使用join拼接

5、完整代码

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>根据字符出现频率排序</title>
  </head>
  <body>
    <p>
     <p>
         给定一个字符串 s ,根据字符出现的 频率 对其进行 降序排序 。一个字符出现的频率 是它出现在字符串中的次数
     </p> 
     <p>
        返回 已排序的字符串。
      如果有多个答案,返回其中任何一个。
     </p>
    </p>
    <p>
        <p>
           输入: s = "tree"
            输出: "eert"
            解释: 'e'出现两次,'r'和't'都只出现一次。
            因此'e'必须出现在'r'和't'之前。此外,"eetr"也是一个有效的答案。 
        </p>
        <p>
            输入: s = "cccaaa"
            输出: "cccaaa"
            解释: 'c'和'a'都出现三次。此外,"aaaccc"也是有效的答案。
            注意"cacaca"是不正确的,因为相同的字母必须放在一起。
        </p>
        <p>
            输入: s = "Aabb"
            输出: "bbAa"
            解释: 此外,"bbaA"也是一个有效的答案,但"Aabb"是不正确的。
            注意'A'和'a'被认为是两种不同的字符。
        </p>
    </p>
    <p>
        将字符串分割成数组,然后利用map统计频次,通过sort排序,最后将排好序的数组通过join拼接为字符串
    </p>
    <script>
        // let  s = "tree"
        // let  s = "cccaaa"
        let s = "eeeelolovtcd"
        frequencySort(s)
        function frequencySort(s){
            // 分割
            let arr = s.split("")
            // console.log(arr);
            // 统计频次
            const newMap = new Map()
            arr.forEach(item => {
                if (newMap.has(item)) {
                    newMap.set(item,newMap.get(item)+1)
                }else{
                    newMap.set(item,1)
                }
            });
            //  console.log(newMap);
            // 排序
            const mapArray = Array.from(newMap.entries());
            mapArray.sort((a,b)=>b[1]-a[1])
            // console.log(mapArray);
            const str = mapArray.map(item => item[0].repeat(item[1])).join('');
            //  console.log(str);
            return str
       
        }

    </script>
  </body>
</html>

6、力扣通过代码

/**
 * @param {string} s
 * @return {string}
 */
var frequencySort = function(s) {
            // 分割
            let arr = s.split("")
            // console.log(arr);
            // 统计频次
            const newMap = new Map()
            arr.forEach(item => {
                if (newMap.has(item)) {
                    newMap.set(item,newMap.get(item)+1)
                }else{
                    newMap.set(item,1)
                }
            });
            //  console.log(newMap);
            // 排序
            const mapArray = Array.from(newMap.entries());
            mapArray.sort((a,b)=>b[1]-a[1])
            // console.log(mapArray);
            const str = mapArray.map(item => item[0].repeat(item[1])).join('');
            //  console.log(str);
            return str
  
};

相关文章:

  • 使用 Python 爬虫获取微店快递费用 item_fee API 接口数据
  • SolidWorks速成教程P3-3【零件 | 第三节】——草图绘制面实线与构造线的区别
  • 贪心算法_翻硬币
  • React中Fragment的使用
  • [Windows] NVIDIA显卡驱动安装去除其中垃圾程序,NVCleanstall
  • Flutter项目试水
  • 【Framework系列之Client】LoadManager、ResourceManager介绍
  • 新的面试题CSS
  • leetcode 416. 分割等和子集
  • DeepSeek-R1:通过强化学习提升大型语言模型推理能力的探索
  • 【机器学习】监督学习-决策树-CART(Classification and Regression Tree,分类与回归树)详尽版
  • 兔兔答题应用于微信考试、付费考试、社会调查问卷、明星知识问答、员工培训考核、模拟自测、企业面试、试题库等多种场景。
  • 【Elasticsearch】index索引相关模块
  • 使用pyCharm创建Django项目
  • 【c++】字符串 string 以及与右值结合
  • 每日一题——字符串的排列
  • STM32 HAL库UART串口数据接收实验
  • kibana es 语法记录 elaticsearch
  • Python--常见库与函数
  • Java使用Redis
  • 失智老人有两个儿子却欠费住养老院两年多,法检合力指定监护人
  • 凤阳文旅局长回应鼓楼瓦片脱落事件:楼宇是否属于文物?施工经费用在何处?
  • 赣州蓉江新区党工委原书记王凌主动交代问题,正接受审查调查
  • 中疾控:适龄儿童要及时、全程接种百白破疫苗
  • 第78届世界卫生大会20日审议通过“大流行协定”
  • 习近平:推进中国式现代化要继续把制造业搞好