1419. Minimum Number of Frogs Croaking

  • 找规律
  • 从后向前思考,有 k 时必须有 a,有 a 时前面必须有 o,并且一一对应
  • 由此构建哈希表,比如出现 k,则出现 a 的次数减一,k 则加一
  • 处理 c 的起始情况
  • 异常情况的判断:若出现 roak中的一个,前面没有与之对应的前一个字符,则返回-1;
  • 最后返回值为 k 的个数,前提是此时哈希表中其他字符计数为0
cpp 复制代码
class Solution {
public:
    int minNumberOfFrogs(string croakOfFrogs) {
        string s = "croak";
        unordered_map<char, int> index; // 每个字符与下标映射
        for(int i = 0; i < s.size(); i++)
            index[s[i]] = i;
        vector<int> hash(s.size());
        for(int i = 0; i < croakOfFrogs.size(); i++)
        {
            if(croakOfFrogs[i] == s[0])
            {
                if(hash[s.size() - 1] != 0)
                    hash[s.size() - 1]--;
                hash[0]++;
            }
            else
            {
                if(hash[index[croakOfFrogs[i]] - 1] == 0)
                    return -1;
                hash[index[croakOfFrogs[i]] - 1]--;
                hash[index[croakOfFrogs[i]]]++;

            }
        }
        for(int i = 0; i < s.size() - 1; i++)
        {
            if(hash[i] != 0)
                return -1;
        }
        return hash[s.size() - 1];
    }
};
相关推荐
早点睡觉好了15 小时前
重排序 (Re-ranking) 算法详解
算法·ai·rag
gihigo199815 小时前
基于全局自适应动态规划(GADP)的MATLAB实现方案
算法
ctyshr16 小时前
C++编译期数学计算
开发语言·c++·算法
zh_xuan17 小时前
最小跳跃次数
数据结构·算法
yumgpkpm17 小时前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
孞㐑¥17 小时前
算法—队列+宽搜(bfs)+堆
开发语言·c++·经验分享·笔记·算法
yufuu9817 小时前
并行算法在STL中的应用
开发语言·c++·算法
zh_xuan17 小时前
单青蛙跳台阶
数据结构·算法
Kx_Triumphs17 小时前
计算几何-旋转卡壳两种实现方案(兼P1452题解
算法·题解
代码游侠17 小时前
学习笔记——Linux字符设备驱动开发
linux·arm开发·驱动开发·单片机·嵌入式硬件·学习·算法